/*
* Copyright (c) 2012, 烟台大学计算机学院
* All rights reserved.
* 作 者:孙永
* 完成日期:2012 年 12 月15日
* 版 本 号:v1.0
* 输入描述:
* 问题描述:
* 程序输出:
* 问题分析:
*算法设计
*/
#include<iostream>
using namespace std;
const int num=6;
int main()
{
int i,j,k;
char temp[20];
char name[num][20]={"老大","老二","小三","强子","小五","小六"};
double score[num]={84,79,89,60,78,92};
for(j=0;j<num-1;++j)
for(i=0;i<num-j-1;++i)
{
if(score[i]<score[i+1])
{
k=score[i];
score[i]=score[i+1];
score[i+1]=k;
strcpy(temp,name[i]);
strcpy(name[i],name[i+1]);
strcpy(name[i+1],temp);
}
}
cout<<"按成绩排序后的结果是:"<<endl;
for(i=0;i<num;++i)
cout<<name[i]<<"\t"<<score[i]<<endl;
for(j=0;j<num-1;++j)
for(i=0;i<num-j-1;++i)
{
if(strcmp(name[i],name[i+1])>0)
{
strcpy(temp,name[i]);
strcpy(name[i],name[i+1]);
strcpy(name[i+1],temp);
k=score[i];
score[i]=score[i+1];
score[i+1]=k;
}
}
cout<<"按姓名排序的结果是"<<endl;
for(i=0;i<num;++i)
cout<<name[i]<<"\t"<<score[i]<<endl;
return 0;
}
运行结果: