C++程序设计-第2周结构体应用

简介: 第一部分 程序阅读  下面的程序建立起了如图所示的动态链表。阅读程序,在草稿纸上画出链表建立的过程,借此学会如何建立链表。可以通过单步执行以辅助理解#include <iostream>using namespace std;struct Student{ long num; float score; struct Student *next;};int m

第一部分 程序阅读

  下面的程序建立起了如图所示的动态链表。阅读程序,在草稿纸上画出链表建立的过程,借此学会如何建立链表。可以通过单步执行以辅助理解

#include  <iostream>
using namespace std;
struct Student
{ 
	long num;
	float score;
	struct Student *next;
};
int main( )
{ 
	Student *head=NULL,*p,*q;
	//下面的程序建立起一个有三个节点的动态链表
	for(int i=0;i<3;i++)
	{	p = new Student;  //分配结点的存储单元
		cin>>p->num>>p->score;
		p->next=NULL;
		if (i==0) 
			head=p;   //如果是首结点,令head取得值
		else
			q->next=p;  //不是首结点,建立起链接来
		q=p;  //p是新建立的结点,q始终是要加入结点的前一个结点
	}
	//输出所有的节点
	p=head;
	while(p!=NULL)
	{	cout<<p->num<<" "<<p->score<<endl;
		p=p->next;
	}
}

第二部分 上机实践
【项目1-有序的结构体数组】在程序中提供了一个已经初始化的结构体,包括学生的学号、C++、高数、英语成绩。编程序,要求对结构体排序并输出。请完成函数的定义。
/*
* 程序的版权和版本声明部分
* Copyright (c)2013, 烟台大学计算机学院学生
* All rightsreserved.
* 文件名称:score.cpp                           
* 作    者:                            
* 完成日期:  年  月   日
* 版本号: v1.0      
* 输入描述:已经在程序中初始化
* 问题描述:将学生成绩信息存储在结构体数组中,对结构体排序并输出
* 输出:按C++降序和按学号升序排序后的学生成绩单
*/
#include <iostream>
using namespace std;
struct Score
{
	char num[14];
	int cpp;
	int math;
	int english;
};
void sort1(Score [],int);  //要自定义的函数
void sort2(Score [],int);
void output(Score [],int);
int main()
{
	Score score[]={{"201152501104",65,69 ,68 },
	{"201152501114",94 ,89 ,63 },
	{"201152501138",67 ,62 ,84 },
	{"201152501204",100 ,65 ,91 },
	{"201152501202",59 ,80 ,55 },
	{"201152501115",92 ,84 ,60 },
	{"201152501201",80 ,92 ,71 },
	{"201152501145",88 ,56 ,67 },
	{"201152501203",62 ,62 ,95 },
	{"201152501140",80 ,60 ,86 },
	{"201152501205",73 ,90 ,94}};
	int stuNum=sizeof(score)/sizeof(score[0]);
	//将所有同学按C++降序排序后输出
	sort1(score,stuNum);
	cout<<"按C++降序排序后:"<<endl;
	output(score,stuNum);
	//将所有同学按学号升序排序后输出
	sort2(score,stuNum);
	cout<<"按学号升序排序后:"<<endl;
	output(score,stuNum);
	return 0;
}

【项目2-读取数据到结构体数组】score.txt(从本文后粘贴自建)中是一些同学的学号、姓名、C++、高数、英语成绩,定义一个学生成绩的结构体数组,其中的成员包括学号(char num[12])、姓名(name)、三门课的成绩(grade)、总分(score))。
(1)从文件中读出数据,存放到你定义的结构体数组中;
(2)输出结构体数组中所有同学的记录。

  提示:我们初次对文件的操作,在上学期的第11周上机实践中,见http://blog.csdn.net/sxhelijian/article/details/8167913 和http://blog.csdn.net/sxhelijian/article/details/8141924,关于文件操作的指导,见博文“C++文件操作初体验”http://blog.csdn.net/sxhelijian/article/details/8126812

  数据文件中的部分数据见本文最后,可自行复制建文件。


【项目3-用结构体数组作计算】接项目2,
(1)从文件中读出数据,存放到你定义的结构体数组中,即项目2(1);
(2)求出每名同学的总分(可以在读入过程中“顺便”计算);
(3)按总分排序(降序);
(4)输出排序后的成绩单;
(5)有30名同学可以获得奖学金,规则是总分高者优先,有挂科不能得奖学金。请输出可以得奖学金同学的名单。
(6)选做:统计各门课及总分的平均成绩、最高和最低成绩、标准偏差,并输出。 
  建议做两个版本:(1)所有功能全在main()函数中;(2)用自定义函数实现各任务


【项目4-动态链表初试】数据依然来自score.txt,在程序中建立一个动态链表:每读入一个同学的数据,计算总分,分配结点的存储空间并赋值,并建立起前后相链的关系。在建立链表的同时,要进行统计,以便于求出所有同学总分的平均成绩。动态链表建立后,从头结点开始,依次输出所有总分高于平均总分且没有挂科的同学的学号、姓名、总分。
   本周第一部分阅读程序部分给出的程序,可以作为项目4的参考。务必请认真阅读,仔细领会。显然项目4要复杂一些:(1)结构体中的成员多些;(2)从文件中读入数据;(3)一边读数据一边得计算总分,为计算总分的平均值也得做些准备;(4)并不是输出所有的节点。不过,沉下心来,用我们已有的知识,这些任务都能解决。玩熟链表,对专业学习很重要,链表在将来的用处将很广,更实用的数据结构也有赖于你对链表的理解。

  

【项目4扩展(选做)】(1)链表建立起来后,将总分低于总均总分的节点删除(注意删除后前后链仍然能够连起来,不用的空间也能正常释放);(2)问题:在完成项目2、3和项目4基础上,请说出利用结构体数组和动态链表实现此类应用各自的优劣,可以将你的体会写到各任务的体会中。



【项目5-玩日期】
  定义一个表示时间(包括年、月、日、时、分、秒)的结构体,然后完成下面的功能(可以在一个main函数中完成,也可以用函数求解,main函数调用即可):
  (1)输入一个时间(注意各部分数据的取值范围)将输入的时间保存在一个结构体变量中;
  (2)输出该日在本年中是第几天(注意闰年问题);
  (3)输出这是这一天中的第几秒;
  (4)输出这是这一年中的第几秒;(不要认为这个数荒唐,在计算中中需要取随机数时需要一个不会重复的“种子数”,这个秒数是常用的。)
  (5)求你输入的时间d天后是哪年哪月哪日,将结果保存在一个结构体变量中输出;(你的万天日期靠这个功能了)——插讲一个故事。当年老贺由小孩儿过百日,想到自己的万日在哪天。编程计算,结果刚过了十几天,那个懊恼啊。第二个万日得再等26年多,第三个万日,谁敢说一定能过上?20岁左右的你,要算清楚了。在第(1)问中输入你的生日及时辰,d值取为10000,可以算出你的万日,大概在26岁多。
  (6)求你输入的时间s秒后是何日何时,将结果保存在一个结构体变量中输出;


【项目5扩展(选做】用结构体变量给定两个时间,求(1)相差多少天?(2)相差多少秒?


【项目6-点结构体与枚举】读程序,写出函数的定义,注意其中枚举类型的用法
enum SymmetricStyle {axisx,axisy,point};//分别表示按x轴, y轴, 原点对称
struct Point{
	double x;  // 横坐标
	double y;  // 纵坐标
};
double distance(Point p1, Point p2);   // 两点之间的距离
double distance0(Point p1);
Point symmetricAxis(Point p,SymmetricStyle style);   //返回对称点
int main( ){
	Point p1={1,5},p2={4,1},p;
	cout<<"两点的距离为:"<<distance(p1,p2)<<endl;
	cout<<"p1到原点的距离为:"<<distance0(p1)<<endl;
	p=symmetricAxis(p1,axisx);
	cout<<"p1关于x轴的对称点为:"<<"("<<p.x<<", "<<p.y<<")"<<endl;
	p=symmetricAxis(p1,axisy);
	cout<<"p1关于y轴的对称点为:"<<"("<<p.x<<", "<<p.y<<")"<<endl;
	p=symmetricAxis(p1,point);
	cout<<"p1关于原点的对称点为:"<<"("<<p.x<<", "<<p.y<<")"<<endl;
	return 0;
}
 
课程主页在:http://blog.csdn.net/sxhelijian/article/details/7910565

附:score.txt中的数据

201152501104 田程 65 69 68 
201152501114 杨金龙 94 89 63 
201152501115 周琳霄 92 84 60 
201152501138 张强 67 62 84 
201152501140 郑好 80 60 86 
201152501145 曹为尚 88 56 67 
201152501201 倪婷 80 92 71 
201152501202 李奥 59 80 55 
201152501203 张佳怡 62 62 95 
201152501204 邓臣冬 100 65 91 
201152501205 汪美娟 73 90 94 
201152501206 赵格君 96 80 58 
201152501207 张文韬 91 63 91 
201152501208 车宜霖 88 84 79 
201152501209 刘正 61 79 99 
201152501210 李东航 62 58 66 
201152501211 李华 96 96 83 
201152501212 李晓鹏 73 88 93 
201152501213 姜君孝 69 64 62 
201152501214 董越 74 59 69 
201152501215 赵浚源 63 58 96 
201152501216 宫凡奇 89 82 60 
201152501217 张咏晖 94 89 77 
201152501218 丁梦瑶 78 93 58 
201152501219 金婷 75 87 84 
201152501220 张娟 90 65 62 
201152501221 姜莉 76 78 81 
201152501222 孙亚雯 90 87 73 
201152501223 郭重 88 68 63 
201152501224 王潇哲 85 94 97 
201152501225 宋心洁 99 69 82 
201152501226 杜婧霏 91 80 98 
201152501227 于晓霞 69 72 99 
201152501228 王莉莉 84 95 94 
201152501229 万雅璐 98 95 64 
201152501230 曲淑霞 67 100 83 
201152501231 高晶 98 81 67 
201152501232 于泽莹 67 64 77 
201152501233 李婧怡 84 72 90 
201152501234 姚宇 92 78 95 
201152501235 于超 87 82 86 
201152501236 李剑 78 86 95 
201152501237 孟雨薇 66 64 58 
201152501238 孙华泽 98 98 74 
201152501239 朱绮梦 73 83 96 
201152501240 周易 56 69 84 
201152501241 蔡庆 60 78 71 
201152501242 姜懿宸 86 94 59 
201152501243 孙雪梅 64 92 66 
201152501244 李芊潭 97 100 55 
201152501245 周祥 100 86 74 
201152501246 吐鲁洪江 73 94 75 
201153503240 王婷婷 68 73 69 
201153503242 宗雪燕 60 82 61 
201153503243 于小涵 79 60 78 
201153503245 钟艺 82 91 97 
201153503246 耿清敏 67 77 60 
201153503248 耿梦启 79 100 57 
201153503249 刘轩辰 59 86 90 
201153503251 贺巧霞 56 87 88 
201153503254 张丽芳 57 81 87 
201154503207 刘蕊 57 89 69 
201158501330 李涛 96 89 73 
201158501332 张新明 68 59 64 
201158501334 曹文战 82 89 73 
201160602108 孔令涛 63 86 80 
201160602124 刘大伟 96 69 98 
201163501101 孟站 58 100 70 
201163501102 王超奇 75 63 89 
201163501104 周涛 68 95 84 
201163501105 贾治国 86 84 100 
201163501106 杨磊 92 66 88 
201163501107 万建新 71 56 83 
201163501108 李宁 70 95 73 
201163501110 赵江彦 58 63 79 
201163501111 杜俊一 61 75 70 
201163501113 邢士峰 56 70 66 
201163501114 李传良 95 90 86 
201163501115 宋吉超 78 91 80 
201163501118 赵方义 70 100 94 
201163501119 闫鲁梅 72 80 100 
201163501121 张明珠 83 89 65 
201163501122 刘沙沙 86 94 71 
201163501123 张星雨 57 82 87 
201163501125 王晓佳 68 97 65 
201163501129 周立军 75 89 87 
201163501130 周颖颖 80 95 68 
201163501131 许倩 71 69 80 
201163501132 于克美 57 82 63 
201163501133 姜芹 89 99 88 
201163501134 姚华玲 75 80 75 
201163501135 杨慧 75 73 70 
201163501136 于媛 73 89 69 
201163501137 杨晓 61 96 74 
201163501139 季莹 71 87 68 
201163501140 周梦如 85 97 77 
201163501228 杨芳艳 57 70 87 
201163501230 吴红丽 55 63 84 
201163501231 程铭 90 77 79 
201163501232 刘雪 65 86 95 
201163501234 黄瑶 100 78 71 
201163502202 陈佩鸿 71 78 76 
201163502204 王晓北 74 56 60 
201163502205 冯科峰 57 79 73 
201163502206 亢亚伟 95 96 79 
201163502207 李梦 87 55 69 
201163502208 何文豪 99 73 85 
201163502210 王柯 60 63 67 
201163502211 唐科军 99 56 66 
201163502212 刘帅 67 92 74 
201163502214 邓佩云 56 55 89 
201163502215 尹琪 92 98 62 
201163502216 丛林 67 93 75 
201163502217 赵东超 59 60 90 
201163502220 郭鹏飞 83 70 96 
201163502221 王金梯 64 92 99 
201163502227 王学 81 63 79 
201163502229 莫敏 80 55 86 
201163502230 李辉 60 70 84 
201163502231 欧阳燕平 75 90 86 
201163502233 任金梅 83 55 91 
201163502238 董文平 55 73 89 
201163502239 王骎 56 60 59 
201163502241 陈龙 78 72 68 
201163502243 杨康迪 82 100 67 
201163503120 邵娅楠 66 73 89 
201163503124 盛善爱 87 70 90 
201163503125 吴秋宇 56 94 77 
201163503127 赵亚振 69 78 89 
201163503128 尹源 66 79 81 
201163503138 张伟凤 71 90 73 
201163503143 刘超超 62 93 95 
201169503132 赵雅楠 100 86 81 
201169503140 高美 58 94 57 
201169503141 宁晓波 98 62 75 
201169503142 王丹 89 70 89 
201169503143 朱影 55 64 63 
201169503144 杨玉萍 73 74 98 
201169503145 魏颖颖 84 57 57 
201170501147 任丽颖 84 64 72 
201170501148 娄俊杰 99 61 86 
201170501155 郭宏超 57 62 97 
201170501156 张伟 100 68 66 
201170501201 杨茂林 55 71 88 
201170501247 范雯婷 77 94 79 
201170502105 齐鹏 87 98 89 
201170502106 尹承志 64 84 75 
201170502107 丁友剑 89 85 71 
201170502108 王旭 71 88 64 
201170502113 王伟杰 100 80 64 
201170502114 齐国鑫 93 92 71 
201170502115 孙琦琦 85 74 70 
201170502116 孙中华 59 61 60 
201170502117 马中平 93 74 58 
201170502118 张秘 64 72 74 
201170502119 杨其星 89 66 83 
201170502120 赵加玉 69 93 99 
201170502121 徐长清 98 81 62 
201170502122 刘小虎 77 65 79 
201170502125 柴志军 94 61 75 
201170502130 张伟平 78 92 100 
201170502131 丁邱红 67 87 100 
201170502134 刘盼 78 67 93 
201170502135 李文洁 56 68 81 
201170502136 车丽娜 99 55 63 
201170502137 李馥辛 100 77 59 
201170502138 刘群 69 79 83 
201170502139 石雨 73 62 93 
201170502140 蔡冬雪 62 56 71 
201170502141 季传贞 86 96 71 
201170502222 李发庭 85 83 82 
201170505101 蔡杭 84 60 90 
201170505249 张倩倩 94 82 68 
201170504112 徐志娇 80 93 76 
201170504113 王彦 96 99 62 
201170504114 夏冬梅 91 87 87 
201170504115 王晶 85 91 57 
201170504116 宁新梅 59 68 68 
201170504124 房饷妤 90 79 66 
201170504142 王甜 57 82 80 

目录
相关文章
|
3月前
|
C++
c++学习笔记07 结构体
C++结构体的详细学习笔记07,涵盖了结构体的定义、使用、数组、指针、嵌套、与函数的交互以及在结构体中使用const的示例和解释。
39 0
|
15天前
|
存储 并行计算 安全
C++多线程应用
【10月更文挑战第29天】C++ 中的多线程应用广泛,常见场景包括并行计算、网络编程中的并发服务器和图形用户界面(GUI)应用。通过多线程可以显著提升计算速度和响应能力。示例代码展示了如何使用 `pthread` 库创建和管理线程。注意事项包括数据同步与互斥、线程间通信和线程安全的类设计,以确保程序的正确性和稳定性。
|
1月前
|
存储 编译器 C++
【C++篇】揭开 C++ STL list 容器的神秘面纱:从底层设计到高效应用的全景解析(附源码)
【C++篇】揭开 C++ STL list 容器的神秘面纱:从底层设计到高效应用的全景解析(附源码)
52 2
|
2月前
|
存储 算法 C++
【C++核心】结构体、共用体详解
这篇文章详细讲解了C++中结构体和共用体的概念、定义、使用场景和案例,包括结构体的创建、数组、指针、嵌套、函数参数传递,以及共用体的特点和应用实例。
27 4
|
2月前
|
编译器 C++
【C++核心】函数的应用和提高详解
这篇文章详细讲解了C++函数的定义、调用、值传递、常见样式、声明、分文件编写以及函数提高的内容,包括函数默认参数、占位参数、重载等高级用法。
22 3
|
2月前
|
C++
继续更新完善:C++ 结构体代码转MASM32代码
继续更新完善:C++ 结构体代码转MASM32代码
|
3月前
|
存储 算法 C++
C++ STL应用宝典:高效处理数据的艺术与实战技巧大揭秘!
【8月更文挑战第22天】C++ STL(标准模板库)是一组高效的数据结构与算法集合,极大提升编程效率与代码可读性。它包括容器、迭代器、算法等组件。例如,统计文本中单词频率可用`std::map`和`std::ifstream`实现;对数据排序及找极值则可通过`std::vector`结合`std::sort`、`std::min/max_element`完成;而快速查找字符串则适合使用`std::set`配合其内置的`find`方法。这些示例展示了STL的强大功能,有助于编写简洁高效的代码。
45 2
|
3月前
|
存储 搜索推荐 Serverless
【C++航海王:追寻罗杰的编程之路】哈希的应用——位图 | 布隆过滤器
【C++航海王:追寻罗杰的编程之路】哈希的应用——位图 | 布隆过滤器
36 1
|
3月前
|
存储 编译器 C++
C++多态实现的原理:深入探索与实战应用
【8月更文挑战第21天】在C++的浩瀚宇宙中,多态性(Polymorphism)无疑是一颗璀璨的星辰,它赋予了程序高度的灵活性和可扩展性。多态允许我们通过基类指针或引用来调用派生类的成员函数,而具体调用哪个函数则取决于指针或引用所指向的对象的实际类型。本文将深入探讨C++多态实现的原理,并结合工作学习中的实际案例,分享其技术干货。
71 0
|
3月前
|
JSON Android开发 C++
Android c++ core guideline checker 应用
Android c++ core guideline checker 应用