《程序设计基础》实验题目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) { //保存的 ...
随机推荐
- Js通用验证
//-----------------------------------------------------js 验证封装 zhy2014-07-10------------------------ ...
- 进销存管理系统, 刚学C++
各位大神们.有什么补充的能够评论一下吗? #include<iostream> #include<string> using namespace std; int G=0;// ...
- ios dyld: Library not loaded: @rpath/xxx.framework/xxx 之根本原因
碰到问题 dyld: Library not loaded: @rpath/xxx.framework/xxx Referenced from: /var/containers/Bundle/Appl ...
- sql server的版本检查
https://support.microsoft.com/en-ph/help/321185/how-to-determine-the-version-edition-and-update-leve ...
- hdu1814Peaceful Commission(2-SAT)
Peaceful Commission Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ...
- 一款超好用的第三方评论插件--Gitalk
一,使用Gitalk的背景: 1.最近在做一个基于Java的个人博客系统,已经基本完工了,突然发现怎么没有评论的操作,如果再从头开始从数据库开始写的话,花费的代价有点大,于是乎我就在网上寻找一款适合我 ...
- Akka源码分析-ActorSystem
由于本人对Akka比较感兴趣,也用Akka开发了一些系统,但对Akka的源码还没有具体分析过,希望研究源码的同时写一点博客跟大家分享.有不当之处还请指正.我准备采取Debug的方式来研究Akka的运行 ...
- Gson 转日期中的错误
今天在用Gson做json转化是遇到一个问题,本地执行没有问题(windows 7),包丢到服务器上(Centos)就报错了. 后经分析发现DateTypeDapter类中取本地环境的日期格式参考ht ...
- php 静态属性和静态变量
- ios-判断手机上是否安装了某个App
方法一 1.获取手机中安装的所有App 1.1.runtime中的方法,所以要导入 #include <objc/runtime.h> 1.2.在 AppDel ...