| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1258 人关注过本帖
标题:冒泡排序,看看有要改进的吗?
取消只看楼主 加入收藏
iceqier
Rank: 1
等 级:新手上路
威 望:1
帖 子:129
专家分:0
注 册:2006-1-22
收藏
 问题点数:0 回复次数:3 
冒泡排序,看看有要改进的吗?
#include<stdio.h>
void swap(int *p1,int *p2)
{
int temp;
temp=*p1;
*p1=*p2;
*p2=temp;
}
void mp_min_to_max(int a[],int count)
{
for(int i=0;i<count-1;i++)
for(int j=i+1;j<count;j++)
if(a[i]>a[j])
swap(&a[i],&a[j]);
}
void main()
{
int a[10];
for(int i=0;i<10;i++)
{
printf("please input number %d: ",i+1);
scanf("%d",&a[i]);
}
mp_min_to_max(a,10);
printf("\nnumber is min to max: ");
for(int j=0;j<10;j++)
{
printf("%d ",a[j]);
}
printf("\n\n");
}
搜索更多相关主题的帖子: 冒泡 改进 
2006-02-14 22:06
iceqier
Rank: 1
等 级:新手上路
威 望:1
帖 子:129
专家分:0
注 册:2006-1-22
收藏
得分:0 
楼2问题,因为是10个数,只要比较9次就行了,所以count-1

楼3问题,我主函数调用了这个mp_min_to_max()函数了呀;

你这样改了,不是从小到大排序,而是选出最小一个数

[此贴子已经被作者于2006-2-14 23:14:34编辑过]


天天摸键盘,整天看代码。。。 E-mail : iceqier520@
2006-02-14 23:13
iceqier
Rank: 1
等 级:新手上路
威 望:1
帖 子:129
专家分:0
注 册:2006-1-22
收藏
得分:0 
我才学了一个月,有什么不对请大家指点

天天摸键盘,整天看代码。。。 E-mail : iceqier520@
2006-02-14 23:34
iceqier
Rank: 1
等 级:新手上路
威 望:1
帖 子:129
专家分:0
注 册:2006-1-22
收藏
得分:0 
我知道这道题不要写得那么长,只要在主函数里实现就可以了

可是,这是我的回家作业,老师要求我们要用嵌套函数和指针做,所以.........

谢谢楼上的,大家一起进步

天天摸键盘,整天看代码。。。 E-mail : iceqier520@
2006-02-14 23:42
快速回复:冒泡排序,看看有要改进的吗?
数据加载中...
 
   



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

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