鱼C论坛

 找回密码
 立即注册
查看: 944|回复: 5

数组问题

[复制链接]
发表于 2021-12-10 22:05:10 | 显示全部楼层 |阅读模式

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

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

x
各位帮我修改这串代码,看看哪里错了谢谢了
  1. #include <stdio.h>
  2. void sort(int *p)
  3. {
  4.         int i,j,t;
  5.     for(i=0;i<6;i++)
  6.     {
  7.             for(j=0;j<6-i;j++)
  8.             if(*(p+i)<*(p+i+1))
  9.             {
  10.                    
  11.                     t=*(p+i);
  12.                 *(p+i)=*(p+i+1);
  13.                     *(p+i+1)=t;
  14.             }
  15.     }
  16. }
  17. int main(void)
  18. {
  19.         int a[]={5,23,31,48,25,67},i;
  20.         sort(a);
  21.         int *p;
  22.         p=a;
  23.         for(i=0;i<6;i++,p++)
  24.         {
  25.                 printf("%4d",*p);
  26.         }
  27.        
  28. }
复制代码
}U9CX3U8]7RJ6~540`B15II.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-12-10 22:27:44 | 显示全部楼层
注释部分是修改的,把i 改j 即可

  1. #include <stdio.h>
  2. void sort(int* p)
  3. {
  4.     int i, j, t;
  5.     for (i = 0; i < 6; i++)
  6.     {
  7.         for (j = 0; j < 6 - i; j++)
  8.             //if (*(p + j) < *(p + j + 1))
  9.             {

  10.                // t = *(p + j);
  11.                 //*(p + j) = *(p + j + 1);
  12.                 //*(p + j + 1) = t;
  13.             }
  14.     }
  15. }
  16. int main(void)
  17. {
  18.     int a[] = { 5,23,31,48,25,67 }, i;
  19.     sort(a);
  20.     int* p;
  21.     p = a;
  22.     for (i = 0; i < 6; i++, p++)
  23.     {
  24.         printf("%4d", *p);
  25.     }

  26. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-12-10 22:49:20 | 显示全部楼层
a327904410 发表于 2021-12-10 22:27
注释部分是修改的,把i 改j 即可

为什么一开始显示的是一串地址吧好像
  1. 6422400  67  48  31  25  23
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-12-10 22:51:21 | 显示全部楼层
Boring1031 发表于 2021-12-10 22:49
为什么一开始显示的是一串地址吧好像
  1. #include <stdio.h>
  2. void sort(int* p)
  3. {
  4.     int i, j, t;
  5.     for (i = 0; i < 6; i++)
  6.     {
  7.         for (j = 0; j < 6 - i; j++)
  8.             if (*(p + j) < *(p + j + 1))
  9.         {

  10.             t = *(p + j);
  11.             *(p + j) = *(p + j + 1);
  12.             *(p + j + 1) = t;
  13.         }
  14.     }
  15. }
  16. int main(void)
  17. {
  18.     int a[] = { 5,23,31,48,25,67 }, i;
  19.     sort(a);
  20.     int* p;
  21.     p = a;
  22.     for (i = 0; i < 6; i++, p++)
  23.     {
  24.         printf("%4d", *p);
  25.     }

  26. }
复制代码


我的输出结果:
  1.   67  48  31  25  23   5
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-12-10 22:54:12 | 显示全部楼层

我的还是那一串,可能编译器不一样?我用的devc
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-12-10 23:09:03 | 显示全部楼层
Boring1031 发表于 2021-12-10 22:54
我的还是那一串,可能编译器不一样?我用的devc

你的冒泡排序写错了,已改回

  1. #include <stdio.h>
  2. void sort(int *p)
  3. {
  4.         int i,j,t;
  5.     for(i=0;i<6;i++)
  6.     {
  7.             for(j=0;j<6-i-1;j++)
  8.             if (*(p + j) < *(p + j + 1))
  9.             {

  10.                t = *(p + j);
  11.                     *(p + j) = *(p + j + 1);
  12.                 *(p + j + 1) = t;
  13.                   
  14.             }
  15.     }
  16. }
  17. int main(void)
  18. {
  19.         int a[]={5,23,31,48,25,67},i;
  20.         sort(a);
  21.         int *p = NULL;
  22.         p=a;
  23.         for(i=0;i<6;i++,p++)
  24.         {
  25.                 printf("%4d",*p);
  26.         }
  27.         
  28. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-1 18:01

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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