鱼C论坛

 找回密码
 立即注册
查看: 2684|回复: 3

[技术交流] 三种方法比较大小

[复制链接]
发表于 2012-3-20 11:09:54 | 显示全部楼层 |阅读模式

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

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

x
#include <iostream>
void print(int m)
{std::cout<<m<<'\t';
}
void sort1(int a[10],int n)
{int i,j,temp;
for(i=0;i<10;i++)
  for(j=0;j<10-i;j++)
  {if(a[j]>a[j+1])
  {temp=a[j];
      a[j]=a[j+1];
   a[j+1]=temp;//冒泡法
  }
   for(i=0;i<10;i++)
    print(a[i]);
  }
}
void sort2(int a[10],int n)
{int i,j,temp;
for(i=0;i<10;i++)
for(j=i+1;j<10;j++)
{if(a[i]>a[j])
temp=a[i];
    a[i]=a[j];
a[j]=temp; //选择法
}
for(i=0;i<10;i++)
    print(a[i]);
}
//这段代码中没有递归调用,直接简单函数调用即可。sort3有错误,简单修改如下:
void sort3(int a[10],int n)
{int i,j,temp,min;
for(i=0;i<10;i++)
{
  min=i;
  for(j=i;j<10;j++)
  {if(a[min]>a[j])min=j;}
     temp=a[min];
     a[min]=a[i];
  a[i]=temp;

}
for(i=0;i<10;i++)
    print(a[i]);  
}
void main(void)
{ int a[10],i;
  std::cout<<"Enter 10 numbers:";
  for(i=0;i<10;i++)
    std::cin>>a[i];
  sort1(a,10);
  sort2(a,10);
sort3(a,10);
system("pause");
  
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2012-3-24 00:48:15 | 显示全部楼层
第三种好像有个名字 忘了- -   我记得还有一种叫插入法的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
 楼主| 发表于 2012-3-25 14:16:13 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2012-3-26 11:54:34 | 显示全部楼层
学习了。。。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-6-6 19:59

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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