C语言实现链表与文件存取的示例代码

目录
  • 此处为main函数的内容
  • 一、输入数据到链表中
  • 二、把链表数据存入文件
  • 三、输出文件
  • 完整代码

本程序主要功能是建立链表,然后把链表数据存储到文件中,然后把文件数据存储到数组中并输出。

不多说了,放代码。

此处为main函数的内容

int main(void)
{
    char filename[50];
    printf("How many ?: ");
    scanf("%d", &n);		/*输入学生数*/
    printf("please input filename: ");
    scanf("%s", filename);	/*输入文件所在路径及名称*/
    Create();       //调用函数建立链表
    save(filename); //调用函数存到文件
    free(phead);//释放phead内存
    show(filename); //调用函数输出文件
    system("pause");
    return 0;
}

一、输入数据到链表中

建立链表并输入数据到链表里

代码如下:

typedef struct stu
{
    char name[20];
    char adr[20];
    int tel;
    struct stu* pnext;
} stu;
int n;	//n存着信息条数
stu* phead=NULL;//phead为链表首地址

void Create()          //建立链表
{
    stu *pend,*pnew;//尾节点,新节点
    pend=phead =(stu*)malloc(sizeof(stu));//分配内存给首节点
    printf("please first input Name, Adress and telephone:\n");
    for(int i=0;i<n;i++)
    {
        pnew=(stu*)malloc(sizeof(stu));  //分配新节点
        pend->pnext=pnew;   //原来的尾节点指向新节点
        pnew->pnext=NULL;  	//新节点的指针为NULL
        printf("NO.%d: ",i+1);
        scanf("%s", pend->name);
        scanf("%s", pend->adr);
        scanf("%d",&pend->tel);
        pend=pnew;  //赋值后指向尾节点
    }
    pnew=pnew->pnext;//指向NULL
    free(pnew);      //释放pnew内存
}

二、把链表数据存入文件

此处用到了fopen、fprintf、fclose等文件操作函数

代码如下:

void save(char *filename)
{
    FILE *w;//文件指针
    if ((w = fopen(filename, "wb")) == NULL){   /*二进制只写打开文件*/
        printf("cannot open file\n");
        exit(1);
    }
    for (int i = 0; i < n; i++)  //链表数据循环输入到文件内
    {
         fprintf(w,"%s ",phead->name);
         fprintf(w,"%s ",phead->adr);
         fprintf(w,"%d", phead->tel);
         fprintf(w,"%s","\r\n");//换行
         phead=phead->pnext;//指向下一个节点
    }
    fclose(w);	//关闭文件
}

三、输出文件

先把文件内容保存到结构体数组内,然后再通过数组输出到屏幕上。

代码如下:

void show(char *filename)		//输出文件
{
    FILE *fp;//文件指针
    stu info[100];  //负责存放文件中的数据,然后输出
    if ((fp = fopen(filename, "rb")) == NULL){   /*二进制只读打开文件*/
        printf("cannot open file\n");
        exit(1);
    }
    for (int i = 0; i < n; i++)
    {
        fscanf(fp,"%s",&(info[i].name));//输出数据到数组
        fscanf(fp,"%s",&(info[i].adr));
        fscanf(fp,"%d",&(info[i].tel));
        printf("%10s%15s%15d\n", info[i].name,
        	info[i].adr, info[i].tel); //输出数据到屏幕
    }
    fclose(fp); //关闭文件
}

完整代码

/*此代码为《C语言从入门到精通(第二版)》第十四章(文件)的【例14.7】的改进版*/
#include<stdio.h>
#include<stdlib.h>
#include<process.h>
typedef struct stu
{
    char name[20];
    char adr[20];
    int tel;
    struct stu* pnext;
} stu;
int n;	//n存着信息条数
stu* phead=NULL;//phead为链表首地址

void Create()/*建立链表*/
{
    stu *pend,*pnew;//尾节点,新节点
    pend=phead =(stu*)malloc(sizeof(stu));//分配内存给首节点
    printf("please first input Name, Adress and telephone:\n");
    for (int i = 0; i < n; i++)
    {
        pnew=(stu*)malloc(sizeof(stu));  //分配新节点
        pend->pnext=pnew;   //原来的尾节点指向新节点
        pnew->pnext=NULL;   //新节点的指针为NULL
        printf("NO.%d: ",i+1);
        scanf("%s", pend->name);//输入数据存到链表中
        scanf("%s", pend->adr);
        scanf("%d",&pend->tel);
        pend=pnew;  //赋值后指向尾节点
    }
    pnew=pnew->pnext;//指向NULL
    free(pnew);      //释放pnew内存
}
void save(char *filename)/*存到文件内*/
{
    FILE *w;//文件指针
    if ((w = fopen(filename, "wb")) == NULL){   /*二进制只写打开文件*/
        printf("cannot open file\n");
        exit(1);
    }
    for (int i = 0; i < n; i++)  //链表数据循环输入到文件里
    {
         fprintf(w,"%s ",phead->name);//数据存入到文件
         fprintf(w,"%s ",phead->adr);
         fprintf(w,"%d", phead->tel);
         fprintf(w,"%s","\r\n");//换行
         phead=phead->pnext;//指向下一个节点
    }
    fclose(w);	//关闭文件
}
void show(char *filename)/*输出文件*/
{
    FILE *fp;//文件指针
    stu info[100];  //负责存放文件中的数据,然后输出
    if ((fp = fopen(filename, "rb")) == NULL){   /*二进制只读打开文件*/
        printf("cannot open file\n");
        exit(1);
    }
    for (int i = 0; i < n; i++)
    {
        fscanf(fp,"%s",&(info[i].name));//输出数据到数组
        fscanf(fp,"%s",&(info[i].adr));
        fscanf(fp,"%d",&(info[i].tel));
        printf("%10s%15s%15d\n", info[i].name,
        	info[i].adr, info[i].tel);//输出数据到屏幕
    }
    fclose(fp);/*关闭文件*/
}

int main(void)
{
    char filename[50];
    printf("How many ?:\n");
    scanf("%d", &n);		/*输入学生数*/
    printf("please input filename: ");
    scanf("%s", filename); /*输入文件所在路径及名称*/
    Create();       //调用函数建立链表
    save(filename); //调用函数存到文件
    free(phead);//释放phead内存
    show(filename); //调用函数输出文件
    system("pause");
    return 0;
}

我尝试过fread和fwrite的做法,但都失败了。

到此这篇关于C语言实现链表与文件存取的示例代码的文章就介绍到这了,更多相关C语言链表与文件存取内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C语言中用于修改文件的存取时间的函数使用

    C语言utime()函数:修改文件的存取时间和更改时间 头文件: #include <sys/types.h> #include <utime.h> 定义函数: int utime(const char * filename, struct utimbuf * buf); 函数说明:utime()用来修改参数filename 文件所属的inode 存取时间.结构utimbuf 定义如下: struct utimbuf { time_t actime; time_t modtime;

  • c语言实现把文件中数据读取并存到数组中

    1.txt 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 2.txt 1 2 3 4 5 2 3 4 5 6 4 5 6 7 8 程序代码: // C++读取文本到数组.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" int readfile1D() { char a[100]; int i; FILE *fp = fopen("1.txt","r"); if(fp =

  • C语言利用链表与文件实现登录注册功能

    C语言实现简登录和注册功能,供大家参考,具体内容如下 C语言实现注册登录 使用链表 使用文件 版本二: 利用链表 此版本使用的链表,第一个版本使用的是数组 数组版本连接 这里我使用的线性链表,一定要注意在判断语句或赋值语句中不可将指针指向未定义的区域,这会产生很大问题,所以一般都需要在链表最后一个节点指向空指针 代码: #include <stdio.h> #include <stdlib.h> #include <malloc.h> #include <stri

  • C语言实现链表与文件存取的示例代码

    目录 此处为main函数的内容 一.输入数据到链表中 二.把链表数据存入文件 三.输出文件 完整代码 本程序主要功能是建立链表,然后把链表数据存储到文件中,然后把文件数据存储到数组中并输出. 不多说了,放代码. 此处为main函数的内容 int main(void) { char filename[50]; printf("How many ?: "); scanf("%d", &n); /*输入学生数*/ printf("please input

  • C语言单链表遍历与求和示例解读

    目录 单链表的遍历 单链表的求和 单链表的遍历 描述: 牛牛从键盘输入一个长度为 n 的数组,问你能否用这个数组组成一个链表,并顺序输出链表每个节点的值. 输入描述: 第一行输入一个正整数 n ,表示数组的长度 第二行输入n个数据 输出描述: 制作一个链表然后输出这个链表的值 输入: 4 5 4 2 1 输出: 5 4 2 1 #include<stdio.h> #include<stdlib.h> typedef int DataType; typedef struct link

  • C语言实现手写Map(数组+链表+红黑树)的示例代码

    目录 要求 结构 红黑树和链表转换策略 hash 使用 要求 需要准备数组集合(List) 数据结构 需要准备单向链表(Linked) 数据结构 需要准备红黑树(Rbtree)数据结构 需要准备红黑树和链表适配策略(文章内部提供,可以自行参考) 建议先去阅读我博客这篇文章C语言-手写Map(数组+链表)(全功能)有助于理解 hashmap使用红黑树的原因是: 当某个节点值过多的时候那么链表就会非常长,这样搜索的时候查询速度就是O(N) 线性查询了,为了避免这个问题我们使用了红黑树,当链表长度大于

  • C语言编程入门必背的示例代码整理大全

    目录 一.C语言必背代码前言 二.一部分C语言必背代码 一.C语言必背代码前言 对于c语言来说,要记得东西其实不多,基本就是几个常用语句加一些关键字而已.你所看到的那些几千甚至上万行的代码,都是用这些语句和关键词来重复编写的.只是他们逻辑功能不一样,那如何快速的上手C语言代码,建议多看多写,下面是小编整理的C语言必背代码. 二.一部分C语言必背代码 1.输出9*9成法口诀,共9行9列,i控制行,j控制列. #include "stdio.h" main() {int i,j,resul

  • C语言实现经典排序算法的示例代码

    目录 一.冒泡排序 1.原理 2.实现 3.算法分析 二.选择排序 1.原理 2.实现 3.算法分析 三.插入排序 1.原理 2.实现 3.算法分析 四.希尔排序 1.原理 2.实现 3.算法分析 总结 一.冒泡排序 1.原理 从数组的头开始不断比较相邻两个数的大小,不断将较大的数右移,一个循环后,最大数移至最后一位,无序数组规模减一.不断重复前面动作,知道数组完全有序. 2.实现 void swap(int* a, int* b) { int temp = *a; *a = *b; *b =

  • C语言不用链表完成学生管理系统(完整代码)

    目录 1.课程设计目的 2.基本要求 3.任务完成情况 4.设计报告 4.1需求分析 4.3详细设计 4.4详细代码 4.5使用说明 4.6测试结果与分析 4.7参考文献 1.课程设计目的 1.更好的理解c语言的相关实现内容,对于c语言的理解得到更好的帮助. 2.实现更方便快捷的应用. 2.基本要求 (1).1.每组完成1个题目的设计:每人独立完成该题目的一个功能模块的实现,并将课程设计报告打印.装订提交. (2).使用标准C语言编制程序,源代码必须采用锯齿型书写格式,必须上机调试通过.运行界面

  • C语言实现可排序通讯录的示例代码

    目录 1.目的 2.分部流程 1.初始化通讯录 2.添加联系人 3.判断联系人是否存在 4.判断通讯录是否已满 5.判断通讯录是否为空 6.通讯录扩容 7.核心函数 8.查找联系人 9.修改联系人 10.清空通讯录 11.删除联系人 12.显示通讯录 13.比较联系人 14.通讯录排序 3.总代码展示 1.目的 写一个实用型通讯录,它有如下功能: 显示目录 void ShowMenu() { printf("#######################\n"); printf(&qu

  • C语言模拟实现密码输入的示例代码

    目录 引言 思路分析 代码实现 代码分析 引言 登录账号时我们要输入密码,密码输入错误时会提示密码错误.有时密码的输入次数会被限制,例如银行卡,当我们3次密码都输入错误时卡会被冻结.下面用C语言模拟实现密码输入. 思路分析 首先要确立一个正确密码,再确定密码输入限制次数,接着用一个scanf语句读取用户输入的密码.将用户输入的密码和先前确定的密码进行比较,如果密码输入正确就显示密码正确,如果密码输入错误就提示密码错误,并告诉用户还有几次输入机会. 代码实现 #include<stdio.h>

  • R语言实现PCA主成分分析图的示例代码

    目录 简介 开始作图 1. PCA 分析图本质上是散点图 2. 为不同类别着色 3. 样式微调 简介 主成分分析(Principal Component Analysis,PCA)是一种无监督的数据降维方法,通过主成分分析可以尽可能保留下具备区分性的低维数据特征.主成分分析图能帮助我们直观地感受样本在降维后空间中的分簇和聚合情况,这在一定程度上亦能体现样本在原始空间中的分布情况,这对于只能感知三维空间的人类来说,不失为一种不错的选择. 再举个形象的栗子,假如你是一本养花工具宣传册的摄影师,你正在

  • 基于C语言实现关机小游戏的示例代码

    目录 关机会写吧 猜数字会写吧 那么合起来 实际效果 关机会写吧 #include <stdlib.h> #include <string.h> #include <stdio.h> int main() { char input[10] = { 0 }; system("shutdown -s -t 60"); again: printf("电脑将于1分钟后关机,输入:我是猪,取消关机!\n"); scanf("%s&

随机推荐