| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 553 人关注过本帖
标题:数组排序求解答
只看楼主 加入收藏
順哥哥orz
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2010-4-20
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:3 
数组排序求解答
main()
{
int i,j,p,q,s,n,a[11]={127,3,6,28,54,68,87,105,162,18};
for(i=0;i<10;i++)
{ p=i;q=a[i];
for(j=i+1;j<10;j++)
if(q<a[j]) {p=j;q=a[j];}
if(p!=i)
{
s=a[i];
a[i]=a[p];
a[p]=s;
}
printf("%d ",a[i]);
}
printf("\ninput number:\n");
scanf("%d",&n);
for(i=0;i<10;i++)
if(n>a[i])
{for(s=9;s>=i;s--) a[s+1]=a[s];
break;}
a[i]=n;
for(i=0;i<=10;i++)
printf("%d ",a[i]);
printf("\n");
}

这是段在已排好序的数组里插入一位数后,数组仍然有序的程序。
哪位帮解释下这段代码的作用(红色部分),
我的理解是排好序后的数组让新的a[i]与a[p]能对上位,不知道这样理解对不,但是我不知道为什么这样写。
哪位帮解答下,稍微详细点- - 谢谢
搜索更多相关主题的帖子: 解答 
2010-04-26 13:18
韩明海
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:253
专家分:749
注 册:2010-4-3
收藏
得分:20 
它首先是把数组由大到小排序,a[0]是最大值
p是记录最大值的下标,q是记录最大值的值
例如 i=0 如果p==i,那么a[0]就是最大值,就不用把最大值和a[0]交换,
if下面的红色就是当前 a[i] 和最大值(a[p])交换的过程。
2010-04-26 15:05
lddwh
Rank: 2
等 级:论坛游民
帖 子:34
专家分:79
注 册:2010-4-7
收藏
得分:0 
实现两个数的交换
2010-04-28 20:18
miracle110
该用户已被删除
收藏
得分:0 
提示: 作者被禁止或删除 内容自动屏蔽
2010-04-28 20:35
快速回复:数组排序求解答
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.011560 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved