|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
#include <stdio.h>
#if(0)
void BubbleSort(int k[],int n)
{
int i,j,temp;
for(i=0;i<n-1;i++)
{
for(j=i+1;j<n;j++)
{
if(k[i]>k[j]);
{
temp=k[j];
k[j]=k[i];
k[i]=temp;
}
}
}
}
#endif
int main()
{
int k[10]={2,8,9,3,8,4,4,0,4,7};
int i,j,temp;
int n=10;//简单的排序,外层循环的每一个元素与内层循环的所有元素比较
for(i=0;i<n-1;i++) //为啥排出顺序不对呢?
{
for(j=i+1;j<n;j++)
{
if(k[i]>k[j]);
{
temp=k[j];
k[j]=k[i];
k[i]=temp;
}
}
}
for(i=0;i<10;i++)
{
printf(" %d",k[i]);
}
putchar(10);
return 0;
}
哈哈 原因很简单
- for(j=i+1;j<n;j++)
- {
- if(k[i]>k[j]);
- {
- temp=k[j];
- k[j]=k[i];
- k[i]=temp;
- }
- }
复制代码
这个循环的第三行if 后面你加了个分号,因此if 已经结束,后面的语句相当于没有条件的执行,所以你的每次循环都会进行交换
|
|