课程主页在
http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在
云学堂“贺老师课堂”同步展示,使用的帐号请到课程主页中查看。
(3)参考解答:
【项目2-带姓名的成绩单】
设score[8]数组中存储8名同学的C++成绩,增加一个数组string name[8]并赋初值,表示同学们的姓名。这两个数组中,每名同学的姓名与成绩的下标要始终保持一致(例如name[i]和score[i]表示同一位同学(下标为i)的姓名和C++成绩,否则会张冠李戴)。
(1)输出按成绩排序后的同学的名单;
(2)输出按同学姓名排序后的成绩单(排序对象是字符串)。
(3)数据由score.txt提供,程序该如何改?(成绩值利用EXCEL软件随机产生,高了的可以得意,低了的请不要介意,照顾下那位垫底老同鞋的情绪。)
#include<iostream>
#include<string>
using namespace std;
const int num=8;
int main()
{
int i,j,t;
string temp;
string name[num]= {"zhao","qian","sun","li","zhou","wu","zheng","wang"};
double score[num]= {79,84,65,89,60,92,78,56};
//(1)按成绩排序并输出结果
//(2)按姓名排序并输出结果
}
提示:排序中交换score中的元素时,只要同时也交换name中的相应元素,就可以实现姓名和成绩的同步(如果交换成绩而不交换姓名,两者的对应关系就被破坏了。)
(1)(2)参考解答:
#include<iostream>
#include<string>
using namespace std;
const int num=8;
int main()
{
int i,j,t;
string temp;
string name[num]= {"zhao","qian","sun","li","zhou","wu","zheng","wang"};
double score[num]= {79,84,65,89,60,92,78,56};
//(1)按成绩排序
for(j=0; j<num-1; j++)
for(i=0; i<num-j-1; i++)
{
if(score[i]<score[i+1])
{
t=score[i];
score[i]=score[i+1];
score[i+1]=t;
temp=name[i];
name[i]=name[i+1];
name[i+1]=temp;
}
}
cout<<"按成绩排序后的结果是:"<<endl;
for(i=0; i<num; i++)
cout<<name[i]<<"\t"<<score[i]<<endl;
//(2)按姓名排序
for(j=0; j<num-1; j++)
for(i=0; i<num-j-1; i++)
{
if(name[i]<name[i+1])
{
temp=name[i];
name[i]=name[i+1];
name[i+1]=temp;
t=score[i];
score[i]=score[i+1];
score[i+1]=t;
}
}
cout<<"按同学姓名排序后有结果是:"<<endl;
for(i=0; i<num; i++)
cout<<name[i]<<"\t"<<score[i]<<endl;
return 0;
}
(3)参考解答:
#include <fstream> //操作文件必写
#include<cstdlib> //调用exit(1)需要包含cstdlib
#include<iostream>
#include<string>
using namespace std;
const int N=100;
int main()
{
int i,j,t;
string name[N];
double score[N];
int num=0;//实际的学生人数
string temp;
ifstream infile("score.txt",ios::in);
if(!infile)
{
cerr<<"open error!"<<endl;
exit(1);
}
while(infile>>name[num]>>score[num]) //当到达文件尾,则循环处理结束。
{
num++;
}
infile.close();
//(1)按成绩排序
for(j=0; j<num-1; j++)
for(i=0; i<num-j-1; i++)
{
if(score[i]<score[i+1])
{
t=score[i];
score[i]=score[i+1];
score[i+1]=t;
temp=name[i];
name[i]=name[i+1];
name[i+1]=temp;
}
}
cout<<"按成绩排序后的结果是:"<<endl;
for(i=0; i<num; i++)
cout<<name[i]<<"\t"<<score[i]<<endl;
//(2)按姓名排序
for(j=0; j<num-1; j++)
for(i=0; i<num-j-1; i++)
{
if(name[i]>name[i+1])
{
temp=name[i];
name[i]=name[i+1];
name[i+1]=temp;
t=score[i];
score[i]=score[i+1];
score[i+1]=t;
}
}
cout<<endl;
cout<<"按同学姓名排序后有结果是:"<<endl;
for(i=0; i<num; i++)
cout<<name[i]<<"\t"<<score[i]<<endl;
return 0;
}
=================== 迂者 贺利坚 CSDN博客专栏================= |== IT学子成长指导专栏 专栏文章的分类目录(不定期更新) ==| |== C++ 课堂在线专栏 贺利坚课程教学链接(分课程年级) ==| |== 我写的书——《逆袭大学——传给IT学子的正能量》 ==| ===== 为IT菜鸟起飞铺跑道,和学生一起享受快乐和激情的大学 ===== |