排序--2006年华中科技大学计算机保研机试真题

无脸男xm 2019-01-17 10:54:24
冒泡排序的方法:
#include<iostream>
using namespace std;
int main() {
int i,j,n,temp;

while(cin>>n) { //换成这样就ok啦啦啦啦
int *a=new int [n];
for(i=0; i<n; i++)
cin>>a[i]; //error:a[i]写成a[n] cin>>写成cin<<
for(i=0; i<n-1; i++) {
for(j=0; j<n-i-1; j++) {
if(a[j]>a[j+1]) { //error: 应该是a[j+1]
temp=a[j];
a[j]=a[j+1];
a[j+1]=temp;
}
}
}
for(i=0; i<n; i++) {
cout<<a[i]<<" ";
}
delete [] a; //???delete array
cout<<endl;
}
return 0;
}
直接调用快排算法:更加快捷
#include<iostream>
#include<algorithm> //使用sort,头文件
using namespace std;
bool cmp(int x,int y)
{
return x<y; //定义排序规则,如果要降序输出,只需改为:x>y
}
int main() {
int n;
while(cin>>n) {
int a[n];
for(int i=0; i<n; i++)
cin>>a[i];
sort(a,a+n,cmp);
for(int i=0; i<n; i++)
cout<<a[i]<<" ";
}
return 0;
}
...全文
87 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
CT8100 2019-01-17
  • 打赏
  • 举报
回复
int *a=new int[n]...

64,654

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧