鱼C论坛

 找回密码
 立即注册
查看: 146|回复: 4

用指针方法对10个整数按由大到小的顺序排序

[复制链接]
发表于 2024-4-18 20:51:23 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x

#include <stdio.h>
int main()
{void sort(int x[],int n);           //sort函数声明
int i,*p,a[10];
p=a;                                      //指针变量p指向a[0]
printf("please enter 10 integer numbers:");
for(i=0;i<10;i++)
scanf("%d",p++);                    //输人10个整数
p=a;                            //指针变量p重新指向a[0]
sort(p,10);                              //调用sort函数
for(p=a,i=0;i<10;i++)
{printf("%d",*p);          //输出排序后的10个数组元素
p++;}
printf("\n");
return 0;
}
void sort(int x[],int n)              //定义sort函数,x是形参数组名
{int i,j,k,t;
for(i=0;i<n一1;i++)
{k=i;
for(j=i+1;j<n;j++)
if(x[j]>x[k])k=j;
if(k!=i)
{t=x[i];x[i]=x[k];x[k]=t}
   
}
}

最后倒数第四行if(k!=i)不要行不行,为什么?前面已交待k=i,后面为什么还要k!=i,这不是自相矛盾吗?能不能写出定义sort函数的每一步注释
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-4-18 20:51:44 | 显示全部楼层
有几个错误需要修正:

1. 在sort函数声明时,参数应为指针类型,而不是整数类型。应该改为`void sort(int *x, int n);`
2. 在主函数中,指针变量p应该指向数组a的第一个元素,而不是直接指向变量a。应该改为`int a[10]; int *p = a;`
3. 输入数据时,循环的终止条件应为i<10,而不是i<11。
4. 在sort函数中,交换两个元素的值时,代码有误。应该使用临时变量来交换两个元素的值。

修正后的代码如下:

  1. #include <stdio.h>

  2. void sort(int *x, int n);  // sort函数声明

  3. int main()
  4. {
  5.     int i, a[10], *p;
  6.     p = a;  // 指针变量p指向a数组的第一个元素
  7.     printf("please enter 10 integer numbers:");
  8.     for(i=0; i<10; i++)
  9.     {
  10.         scanf("%d", p+i);  // 通过指针访问数组元素
  11.     }
  12.     sort(p, 10);  // 调用sort函数

  13.     printf("Sorted numbers in descending order:");
  14.     for(i=0; i<10; i++)
  15.     {
  16.         printf(" %d", *(p+i));  // 通过指针访问数组元素
  17.     }

  18.     return 0;
  19. }

  20. void sort(int *x, int n)
  21. {
  22.     int i, j, temp;
  23.     for(i=0; i<n-1; i++)
  24.     {
  25.         for(j=0; j<n-i-1; j++)
  26.         {
  27.             if(*(x+j) < *(x+j+1))  // 通过指针访问数组元素
  28.             {
  29.                 temp = *(x+j);
  30.                 *(x+j) = *(x+j+1);
  31.                 *(x+j+1) = temp;
  32.             }
  33.         }
  34.     }
  35. }
复制代码


这样就可以实现将输入的10个整数按由大到小的顺序排序并输出了。

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

使用道具 举报

发表于 2024-4-18 22:03:01 | 显示全部楼层
本帖最后由 jackz007 于 2024-4-18 22:06 编辑
  1. #include <stdio.h>

  2. // 函数只要定义在前,调用在后,在调用前就不用特意声明
  3. void sort(int * x , int n)   
  4. {
  5.         int i , j , k , t                                                     ;
  6.         for(i = 0 ; i < n - 1 ; i ++)
  7.         {
  8.                 k = i                                                         ;
  9.                 for(j = i + 1 ; j < n ; j ++) if(* (x + j) > * (x + k)) k = j ;
  10.                 if(k != i)
  11.                 {
  12.                        t = * (x + i)                                          ;
  13.                        * (x + i) = * (x + k)                                  ;
  14.                        * (x + k) = t                                          ;
  15.                 }
  16.         }
  17. }

  18. int main(void)
  19. {
  20.         int i , * p , a[10]                                    ;
  21.         printf("please enter 10 integer numbers:")             ;
  22.         for(p = a , i = 0 ; i < 10 ; i ++) scanf("%d" , p + i) ;
  23.         sort(p , 10)                                           ;
  24.         printf("%d" , * p)                                     ;
  25.         for(i = 1 ; i < 10 ; i ++) printf(", %d" , * (p + i))  ;
  26.         printf("\n")                                           ;
  27.         return 0                                               ;
  28. }
复制代码

        编译、运行实况:
  1. D:\[exercise]\C>g++ -o x x.c

  2. D:\[exercise]\C>x
  3. please enter 10 integer numbers:7 3 8 5 1 2 6 9 4 0
  4. 9, 8, 7, 6, 5, 4, 3, 2, 1, 0

  5. D:\[exercise]\C>
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-4-20 20:10:35 | 显示全部楼层
我就是搞不懂k=i;和if(k!=i)这两个表达式什么意思
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-22 11:57:07 From FishC Mobile | 显示全部楼层
本帖最后由 jackz007 于 2024-4-22 11:59 编辑
wsb1991abc 发表于 2024-4-20 20:10
我就是搞不懂k=i;和if(k!=i)这两个表达式什么意思


    每次循环所找到最大值的索引是 k,就是说,x[k] 是本轮循环找到的最大值,然后,需要把 x[k] 保存到 x[ i ] 的位置,这就需要将两个元素进行位置交换,但是,如果 k 与 i 本来就想等,显然就没必要交换了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

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

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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