鱼C论坛

 找回密码
 立即注册
查看: 1365|回复: 3

[已解决]没有输出

[复制链接]
发表于 2023-12-9 10:17:02 | 显示全部楼层 |阅读模式
本帖为密码帖 ,请输入密码 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-12-9 10:17:54 | 显示全部楼层    本楼为最佳答案   
您的代码中有几个问题需要注意。

首先,您声明了两个变量a和b,但是没有使用它们。可以将这两个变量删掉,因为它们对解决问题没有作用。

其次,在循环输出数组元素时,您使用了`for(i=0; i<n; i++)`,但是在循环体内,没有打印出数组元素。您可以增加一条语句,例如`printf("%d ", a);`,在每次循环中打印出数组元素。

另外,您在每次交换两个元素位置的时候,没有使用临时变量保存一个元素的值。这会导致元素交换不正确。可以使用一个临时变量temp来保存一个元素的值,然后再进行交换。

最后,您在排序算法中使用了冒泡排序,这是一种简单但是效率较低的排序算法。如果数组较大,性能可能会受到影响。您可以考虑使用其他更高效的排序算法,例如快速排序或归并排序。

下面是修改后的代码:
  1. #include <stdio.h>
  2. int main()
  3. {
  4.     int n, i, j, temp, flag = 1, k = 0;
  5.     scanf("%d", &n);
  6.     int a[n];
  7.     for (i = 0; i < n; i++) {
  8.         scanf("%d", &a[i]);
  9.     }
  10.     // 删除重复元素
  11.     for (i = 0; i < n - 1; i++) {
  12.         for (j = i + 1; j < n; j++) {
  13.             if (a[i] == a[j]) {
  14.                 flag = 0;
  15.                 break;
  16.             }
  17.         }
  18.         if (flag) {
  19.             a[k++] = a[i];
  20.         }
  21.         flag = 1;
  22.     }
  23.     a[k++] = a[n - 1];
  24.     // 排序
  25.     for (i = 0; i < k - 1; i++) {
  26.         for (j = 0; j < k - 1 - i; j++) {
  27.             if (a[j] > a[j + 1]) {
  28.                 temp = a[j];
  29.                 a[j] = a[j + 1];
  30.                 a[j + 1] = temp;
  31.             }
  32.         }
  33.     }
  34.     // 输出
  35.     for (i = 0; i < k; i++) {
  36.         printf("%d ", a[i]);
  37.     }
  38.     return 0;
  39. }
复制代码

希望对您有所帮助!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-12-9 10:21:24 | 显示全部楼层
FishC 发表于 2023-12-9 10:17
您的代码中有几个问题需要注意。

首先,您声明了两个变量a和b,但是没有使用它们。可以将这两个变量删掉, ...

如果想用另一个数组储存呢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-12-9 10:22:11 | 显示全部楼层
mamaaini 发表于 2023-12-09 10:21
如果想用另一个数组储存呢

如果您想使用另一个数组来存储去重后的元素,可以按照以下方式修改代码:
  1. #include <stdio.h>
  2. int main() {
  3.     int n, i, j, temp, flag, k = 0;
  4.     scanf("%d", &n);
  5.     int arr[n];
  6.     // 输入数组
  7.     for(i = 0; i < n; i++) {
  8.         scanf("%d", &arr[i]);
  9.     }
  10.     // 去重并排序
  11.     for (i = 0; i < n-1; i++) {
  12.         flag = 1;
  13.         for (j = i+1; j < n; j++) {
  14.             if (arr[i] == arr[j]) {
  15.                 flag = 0;  // 找到重复元素
  16.                 break;
  17.             }
  18.         }
  19.         if (flag) {  // 如果不是重复元素,则进行排序
  20.             for (j = i+1; j < n; j++) {
  21.                 if (arr[i] > arr[j]) {
  22.                     temp = arr[i];
  23.                     arr[i] = arr[j];
  24.                     arr[j] = temp;
  25.                 }
  26.             }
  27.             k++;
  28.         }
  29.     }
  30.    
  31.     // 输出
  32.     for (i = 0; i < k; i++) {
  33.         printf("%d ", arr[i]);
  34.     }
  35.     return 0;
  36. }
复制代码

这个修改后的代码会在输入数组后,先去除重复元素,然后对剩下的非重复元素进行排序,并将结果存储在新的数组`arr`中。最后,再输出新数组中的元素。

希望对您有所帮助!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-13 13:15

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表