《程序设计基础》实验题目2 c文件读取(反序列化?) 链表排序
题目:
每个学生的信息卡片包括学号、姓名和成绩三项。定义存储学生信息的单向链表的结点类型;编写函 数,由文件依次读入 n(n≥0)个学生的信息,创建一个用于管理学生信息的单向链表;编写函数,对 该链表进行整理,保证该单向链表的结点顺序满足学号从小到大的顺序。
算法的设计与分析:
- 定义学生类型结构体(含有分量id,name,score),定义链表节点结构体(含有分量student结构体stu和指向下一个节点的指针next)
- 从文件读取,采用fopen方法返回FILE指针,用fscanf方法读取数据并创建节点组成链表
- 还可以使用freopen的方法,直接scanf即可
- 或者用我一开始的土方法,用fgets函数读取一行,用stroke分割该行字符串,将字符串转化成int,创建结构体。比上面的方法复杂多了。
- 按学号排序,采用插入排序的方法,插入排序,以sorted(初始为第一个元素)为边界,将sorted后的一个节点插在前面已经排好的链表中,直到sorted后没有节点
注意:
- char* 结构体*等指针要用必须分配空间
- 分配空间通常使用malloc函数,A* a=(*A)malloc(sizeof(A))
- malloc申请的空间要free掉,free(a)
- malloc和free这一对与new和delete这一对非常像,c++里动态分配空间用new,c里要用malloc
源代码(talk is cheap,show me the code)(屁话少说,放码过来)
#include <stdio.h>
#include<malloc.h>
#define NAME_MAX 20 //名字的最长长度 typedef struct my_student {
int id;
char* name;
int score;
} student;
typedef struct my_list_node {
student stu;
struct my_list_node *next;
} Node; Node* getStuFromFile(char *path) {
//从文件中读取学生数据创建单链表并返回头指针
FILE *stu_file;
stu_file = fopen(path, "r");
if (stu_file == NULL) {//如果路径不正确
printf("file path error!");
return ;
}
//循环从文件中读取数据创建节点
Node* head = (Node*)malloc(sizeof(Node));//哨兵节点
Node* current_node = head;//用于循环赋值时表示当前节点
while (!feof(stu_file)) {
Node* temp = (Node*)malloc(sizeof(Node));
//id ,name,score分别表示临时节点的student的id等
int* id =&( temp->stu.id);
temp->stu.name = (char*)malloc(sizeof(char)*NAME_MAX);
char* name = temp->stu.name;
int* score = &(temp->stu.score);
//从文件中读取临时节点的各个数据并赋值
fscanf(stu_file, "%d %s %d", id, name, score);
//将临时节点设为当前节点的子节点
current_node->next = temp;
current_node = current_node->next;
}
current_node->next = ;
fclose(stu_file);
return head;
}
void showStuInfor(Node* node) {
//递归打印每个学生的信息
if (node != ) {
printf("%d %s %d\n", node->stu.id, node->stu.name, node->stu.score);
if (node->next != ) {
//递归
showStuInfor(node->next);
}
}
} void insertNode(Node* preL, Node* preR) {
//在preL节点后插入preR后的节点
Node* insert= preR->next;
preR->next = preR->next->next;
insert->next = preL->next;
preL->next = insert;
}
void sortListByStuId(Node *head) {
//插入排序,以sorted为边界,将sorted后的一个节点插在前面已经排好的链表中,直到sorted后没有节点 //初始化sorted有一个节点,算是已经排好序
Node* sorted = head->next;
//将sorted后的一个节点插到前面
while (sorted->next != ) {
Node* insert = sorted->next;
Node* loc = head;
//从head开始遍历该插入到什么地方
while (insert->stu.id > loc->next->stu.id) {
loc = loc->next;
}
//如果loc与sorted不相等执行插入,如果相等说明要插入的元素比sorted之前的都大,直接让sorted后移即可
if (loc != sorted) {
insertNode(loc, sorted);
}
else {
sorted = sorted->next;
}
}
}
void freeNodes(Node* head) {
//递归释放malloc申请的空间
if (head != ) {
if (head->next != ) {
//释放name占用的空间
free(head->next->stu.name);
//递归释放
freeNodes(head->next);
}
free(head);
}
}
void test() {
//测试函数
//从文件中读取学生数据并打印
char path[] = "D:\\student.txt";
Node* students = getStuFromFile(path);
showStuInfor(students->next);
printf("\n sorted:\n");
//按学号排序后打印学生数据
sortListByStuId(students);
showStuInfor(students->next);
freeNodes(students);
} int main() {
test();
}
The end
《程序设计基础》实验题目2 c文件读取(反序列化?) 链表排序的更多相关文章
- 微信小程序开发——活动规则类文案文件读取及自动转换为小程序排版代码
前言: 最近做的小程序活动规则内容比较多,且一直处于修改中.由于小程序并不支持类似Html5中的预排版,所以,活动规则内容修改较大的时候,仍需要对新的内容用小程序的<text>组件做下排版 ...
- PowerShell中进行文件读取,信息排序,分类计数。
这是国外某大学QA的一道作业题,读取mainlog文件中的每一行信息,并获取有效的信息,也就是每条信息中第四个@后面的内容,然后进行分类与计数,要求是用Perl写,但我是用PowerShell完成的, ...
- 【代码审计】大米CMS_V5.5.3 任意文件读取漏洞分析
0x00 环境准备 大米CMS官网:http://www.damicms.com 网站源码版本:大米CMS_V5.5.3试用版(更新时间:2017-04-15) 程序源码下载:http://www ...
- 【代码审计】XYHCMS V3.5任意文件读取漏洞分析
0x00 环境准备 XYHCMS官网:http://www.xyhcms.com/ 网站源码版本:XYHCMS V3.5(2017-12-04 更新) 程序源码下载:http://www.xyhc ...
- 【代码审计】QYKCMS_v4.3.2 任意文件读取漏洞分析
0x00 环境准备 QYKCMS官网:http://www.qykcms.com/ 网站源码版本:QYKCMS_v4.3.2(企业站主题) 程序源码下载:http://bbs.qingyunke. ...
- Java基础-输入输出-2.编写IoDemo.java的Java应用程序,程序完成的功能是:首先读取text.txt文件内容,再通过键盘输入文件的名称为iodemo.txt,把text.txt的内容存入iodemo.txt
2.编写IoDemo.java的Java应用程序,程序完成的功能是:首先读取text.txt文件内容,再通过键盘输入文件的名称为iodemo.txt,把text.txt的内容存入iodemo.txt ...
- 从零开始学 Web 之 HTML5(三)网络监听,全屏,文件读取,地理定位接口,应用程序缓存
大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...
- Creating Dialogbased Windows Application (4) / 创建基于对话框的Windows应用程序(四)Edit Control、Combo Box的应用、Unicode转ANSI、Open File Dialog、文件读取、可变参数、文本框自动滚动 / VC++, Windows
创建基于对话框的Windows应用程序(四)—— Edit Control.Combo Box的应用.Unicode转ANSI.Open File Dialog.文件读取.可变参数.自动滚动 之前的介 ...
- 在C#程序中,创建、写入、读取XML文件的方法
一.在C#程序中,创建.写入.读取XML文件的方法 1.创建和读取XML文件的方法,Values为需要写入的值 private void WriteXML(string Values) { //保存的 ...
随机推荐
- android studio中xml文件代码提示问题
在系统控件中输入“a”能提示出android:id等所有属性.而在第三方库的控件中输入“a”只会提示“appNs”,但如果手动写app:id="@+id/aaa"系统也是可以识别的 ...
- 转 一个SMD 0805的LED的电流,电压,亮度关系表
Vf就是led的导通电压. 一个SMD 0805的LED的电流,电压,亮度关系表Vf If(算) 亮度1.74v 0.46mA 做指示灯不刺眼刚 ...
- linux下的so、o、lo、a、la文件的区别
o: 编译的目标文件a: 静态库,其实就是把若干o文件打了个包so: 动态链接库(共享库) lo: 使用libtool编译出的目标文件,其实就是在o文件中添加了一些信息la: 使用libtool编译出 ...
- notepad + +使用步骤
原文地址:https://blog.csdn.net/so_geili/article/details/79317001#一-安装notepad 一. 安装notepad + + notepad+ ...
- scrapy 框架持久化存储
1.基于终端的持久化存储 保证爬虫文件的parse方法中有可迭代类型对象(通常为列表或字典)的返回,该返回值可以通过终端指令的形式写入指定格式的文件中进行持久化操作. # 执行输出指定格式进行存储:将 ...
- ACM_填格子
填格子 Time Limit: 2000/1000ms (Java/Others) Problem Description: 在一个n*n格子里边已经填了部分大写字母,现在给你个任务:把剩下的格子也填 ...
- [ Luogu Contest 10364 ] TG
\(\\\) \(\#A\) 小凯的数字 给出两个整数\(L,R\),从\(L\)到\(R\)按顺序写下来,求生成整数对\(9\)取模后的答案. 例如\(L=8,R=12\),生成的数字是\(8910 ...
- jQuery五屏轮播手风琴切换代码
jQuery五屏轮播手风琴切换代码 在线演示本地下载
- 通过yum命令搭建lamp环境(centos6.5)
centos 6.5 1.yum安装和源代码编译在使用的时候没啥区别,但是安装的过程就大相径庭了,yum只需要3个命令就可以完成,源代码需要13个包,还得加压编译,步骤很麻烦,而且当做有时候会出错,源 ...
- Python--10、线程
线程 每个进程里都有一个控制线程,进程不是一个执行单位,线程是执行单位,进程是资源单位(资源隔离).进程下可以开多个线程,多线程共享进程内的资源.创建线程的速度比创建进程的速度快,因为创建线程不需要再 ...