《程序设计基础》实验题目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的变量的数据类型
文章首发: http://www.cnblogs.com/sprying/p/4349426.html 本文罗列了一般的Js中类型检测的方法,实际上是每个新手在构建Js知识体系时,都要知晓的,而我只是 ...
- HTTP Status 500 - Could not write content: could not initialize proxy - no Session
分析出现no Session错误的原因以及给出解决方案: 使用SpringMVC + JSON数据返回时,经常会出现no Session的错误: 报错原因:因为懒加载在提取关联对象的属性值的时候发现E ...
- 什么是JavaScript对象?
对象是JavaScript的基本数据类型.对象是一种复合值:它将很多值(原始值或者其他对象)聚合在一起,可通过名字访问这些值.对象也可看做是属性的无序集合,每个属性都是一个名/值对.属性名是字符串,因 ...
- 对于Mobile模块化的概念认知(小白)
最近刚刚学习了Mobile的一些基础知识,把它整理一下方便自己的学习 那什么是Mobile呢? 自己的理解是将一个项目中共同的部分抽出来,这样就形成了Mobile模块. 为什么要使用Mobile呢? ...
- $P5269 欧稳欧再次学车$
\(problem\) 哇 看各位巨佬都来发\(T1\)的题解 我也来发一篇.(别的题目不会别瞎bb) 题目大意就是 \(T\) 秒 能走多少路程 第一行六个整数 \(T,N,L,R,X,K\) 接下 ...
- 【知识总结】线性筛_杜教筛_Min25筛
首先感谢又强又嘴又可爱脸还筋道的国家集训队(Upd: WC2019 进候选队,CTS2019 不幸 rk6 退队)神仙瓜 ( jumpmelon ) 给我讲解这三种筛法~~ 由于博主的鸽子属性,这篇博 ...
- C#内容格式刷html 转成txt
/// <summary> /// 内容格式刷 /// </summary> /// <param name="strHtml">要格式的文本& ...
- 一键生成Spring MVC + MyBatis + maven项目
首先创建一个新的maven项目,在src/main/java创建一个类Test 然后在Test复制以下代码: import java.io.*; import java.sql.Connection; ...
- CSS3悬浮动画效果
利用CSS3的伪类元素hover以及transform,transition等动画属性,可以做出一些炫酷的动画效果.下面将一些项目中使用到的示例发布出来,供大家一起学习研究.演示地址:runjs. 浏 ...
- [ SCOI 2009 ] 最长距离
\(\\\) \(Description\) 一个\(N\times M\)的网格图中有一些坏点,图是四联通的. 你至多可以拿走\(K\)个坏点,求拿走后联通的点对中欧几里得距离最大是多少. \(N, ...