课程主页在
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菜鸟起飞铺跑道,和学生一起享受快乐和激情的大学 ===== |