|
发表于 2023-12-9 10:17:54
|
显示全部楼层
本楼为最佳答案
您的代码中有几个问题需要注意。
首先,您声明了两个变量a和b,但是没有使用它们。可以将这两个变量删掉,因为它们对解决问题没有作用。
其次,在循环输出数组元素时,您使用了`for(i=0; i<n; i++)`,但是在循环体内,没有打印出数组元素。您可以增加一条语句,例如`printf("%d ", a[i]);`,在每次循环中打印出数组元素。
另外,您在每次交换两个元素位置的时候,没有使用临时变量保存一个元素的值。这会导致元素交换不正确。可以使用一个临时变量temp来保存一个元素的值,然后再进行交换。
最后,您在排序算法中使用了冒泡排序,这是一种简单但是效率较低的排序算法。如果数组较大,性能可能会受到影响。您可以考虑使用其他更高效的排序算法,例如快速排序或归并排序。
下面是修改后的代码:
- #include <stdio.h>
- int main()
- {
- int n, i, j, temp, flag = 1, k = 0;
- scanf("%d", &n);
- int a[n];
- for (i = 0; i < n; i++) {
- scanf("%d", &a[i]);
- }
- // 删除重复元素
- for (i = 0; i < n - 1; i++) {
- for (j = i + 1; j < n; j++) {
- if (a[i] == a[j]) {
- flag = 0;
- break;
- }
- }
- if (flag) {
- a[k++] = a[i];
- }
- flag = 1;
- }
- a[k++] = a[n - 1];
- // 排序
- for (i = 0; i < k - 1; i++) {
- for (j = 0; j < k - 1 - i; j++) {
- if (a[j] > a[j + 1]) {
- temp = a[j];
- a[j] = a[j + 1];
- a[j + 1] = temp;
- }
- }
- }
- // 输出
- for (i = 0; i < k; i++) {
- printf("%d ", a[i]);
- }
- return 0;
- }
复制代码
希望对您有所帮助!
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。 |
|