| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 423 人关注过本帖
标题:自己编得排序小程序?
只看楼主 加入收藏
zhufeifei
Rank: 1
等 级:新手上路
威 望:2
帖 子:402
专家分:0
注 册:2006-8-11
收藏
 问题点数:0 回复次数:2 
自己编得排序小程序?
#include<stdio.h>
#define max 10
#define DataType int
typedef struct
{
DataType m[max];
int length;
}List;
int main()
{
int i,j,temp;
List Q;
printf("input ten interge:");
for(i=0;i<max;i++)
scanf("%d",&Q.m[i]);
for(i=0;i<max;i++)
{
j=i+1;
while(j<max)
{
while(Q.m[i]<Q.m[j])
++j;
temp=Q.m[i];
Q.m[i]=Q.m[j];
Q.m[j]=temp;
}
}
printf("The new squence is:");
for(i=1;i<max;i++)//为什么如果i=0开始输出的话,输出排序数的最前面会多个-44?
printf("%d\t",Q.m[i]);
getch();
return;
}
本来想把线性表用C语言写写,可惜好像没什么用?还有上面这个问题?谢谢!
搜索更多相关主题的帖子: include 
2006-11-30 14:43
Welton
Rank: 2
等 级:论坛游民
帖 子:65
专家分:38
注 册:2006-10-25
收藏
得分:0 
for(i=0;i<max;i++) //这里应该为j<max-1
{
j=i+1;
while(j<max)
{
while(Q.m[i]<Q.m[j]) //如果Q.m[i]是最小的话,那么,j有可能变成max,而Q.m[max]是不存在的吧!
++j;
temp=Q.m[i];
Q.m[i]=Q.m[j];
Q.m[j]=temp;
}
}

[此贴子已经被作者于2006-11-30 19:27:30编辑过]


只是喜欢编程而已!
2006-11-30 19:26
C语言学习者
Rank: 4
等 级:贵宾
威 望:13
帖 子:1278
专家分:0
注 册:2006-9-26
收藏
得分:0 

#include<stdio.h>
#define max 10
#define DataType int
typedef struct
{
DataType m[max];
int length;
}List;
int main()
{
int i,j,temp;
List Q;
printf("input ten interge:\n");
for(i=0;i<max;i++)
scanf("%d",&Q.m[i]);
for(i=0;i<max;i++)
{
j=i+1;
while(j<max)
{
while(Q.m[i]<=Q.m[j])
++j;
if(max>j)/*刚才楼上己经说,如果不这样做会把越界范围的数赋予Q.m[0]*/
{temp=Q.m[i];
Q.m[i]=Q.m[j];
Q.m[j]=temp;}

}

}
printf("The new squence is:\n");
for(i=0;i<max;i++)
printf("%d\n",Q.m[i]);
getch();
return;
}


谁有强殖装甲第二部,可以Q我460054868
2006-11-30 20:24
快速回复:自己编得排序小程序?
数据加载中...
 
   



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

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