欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言實(shí)現(xiàn)鏈表與文件存取的示例代碼

 更新時間:2022年04月25日 14:32:38   作者:CVE-檸檬i  
這篇文章主要和大家分享C語言實(shí)現(xiàn)鏈表與文件存取的示例代碼,可以實(shí)現(xiàn)建立鏈表,然后把鏈表數(shù)據(jù)存儲到文件中,然后把文件數(shù)據(jù)存儲到數(shù)組中并輸出,感興趣的可以學(xué)習(xí)一下

本程序主要功能是建立鏈表,然后把鏈表數(shù)據(jù)存儲到文件中,然后把文件數(shù)據(jù)存儲到數(shù)組中并輸出。

不多說了,放代碼。

此處為main函數(shù)的內(nèi)容

int main(void)
{
    char filename[50];
    printf("How many ?: ");
    scanf("%d", &n);		/*輸入學(xué)生數(shù)*/
    printf("please input filename: ");
    scanf("%s", filename);	/*輸入文件所在路徑及名稱*/
    Create();       //調(diào)用函數(shù)建立鏈表
    save(filename); //調(diào)用函數(shù)存到文件
    free(phead);//釋放phead內(nèi)存
    show(filename); //調(diào)用函數(shù)輸出文件
    system("pause");
    return 0;
}

一、輸入數(shù)據(jù)到鏈表中

建立鏈表并輸入數(shù)據(jù)到鏈表里

代碼如下:

typedef struct stu
{
    char name[20];
    char adr[20];
    int tel;
    struct stu* pnext;
} stu;
int n;	//n存著信息條數(shù)
stu* phead=NULL;//phead為鏈表首地址
 
void Create()          //建立鏈表
{
    stu *pend,*pnew;//尾節(jié)點(diǎn),新節(jié)點(diǎn)
    pend=phead =(stu*)malloc(sizeof(stu));//分配內(nèi)存給首節(jié)點(diǎn)
    printf("please first input Name, Adress and telephone:\n");
    for(int i=0;i<n;i++)
    {
        pnew=(stu*)malloc(sizeof(stu));  //分配新節(jié)點(diǎn)
        pend->pnext=pnew;   //原來的尾節(jié)點(diǎn)指向新節(jié)點(diǎn)
        pnew->pnext=NULL;  	//新節(jié)點(diǎn)的指針為NULL
        printf("NO.%d: ",i+1);
        scanf("%s", pend->name);
        scanf("%s", pend->adr);
        scanf("%d",&pend->tel);
        pend=pnew;  //賦值后指向尾節(jié)點(diǎn)
    }
    pnew=pnew->pnext;//指向NULL
    free(pnew);      //釋放pnew內(nèi)存
}

二、把鏈表數(shù)據(jù)存入文件

此處用到了fopen、fprintf、fclose等文件操作函數(shù)

代碼如下:

void save(char *filename)
{
    FILE *w;//文件指針
    if ((w = fopen(filename, "wb")) == NULL){   /*二進(jìn)制只寫打開文件*/
        printf("cannot open file\n");
        exit(1);
    }
    for (int i = 0; i < n; i++)  //鏈表數(shù)據(jù)循環(huán)輸入到文件內(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;//指向下一個節(jié)點(diǎn)
    }
    fclose(w);	//關(guān)閉文件
}

三、輸出文件

先把文件內(nèi)容保存到結(jié)構(gòu)體數(shù)組內(nèi),然后再通過數(shù)組輸出到屏幕上。

代碼如下:

void show(char *filename)		//輸出文件
{
    FILE *fp;//文件指針
    stu info[100];  //負(fù)責(zé)存放文件中的數(shù)據(jù),然后輸出
    if ((fp = fopen(filename, "rb")) == NULL){   /*二進(jìn)制只讀打開文件*/
        printf("cannot open file\n");
        exit(1);
    }
    for (int i = 0; i < n; i++)
    {
        fscanf(fp,"%s",&(info[i].name));//輸出數(shù)據(jù)到數(shù)組
        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); //輸出數(shù)據(jù)到屏幕
    }
    fclose(fp); //關(guān)閉文件
}        

完整代碼

/*此代碼為《C語言從入門到精通(第二版)》第十四章(文件)的【例14.7】的改進(jìn)版*/
#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存著信息條數(shù)
stu* phead=NULL;//phead為鏈表首地址
 
void Create()/*建立鏈表*/
{
    stu *pend,*pnew;//尾節(jié)點(diǎn),新節(jié)點(diǎn)
    pend=phead =(stu*)malloc(sizeof(stu));//分配內(nèi)存給首節(jié)點(diǎn)
    printf("please first input Name, Adress and telephone:\n");
    for (int i = 0; i < n; i++)
    {
        pnew=(stu*)malloc(sizeof(stu));  //分配新節(jié)點(diǎn)
        pend->pnext=pnew;   //原來的尾節(jié)點(diǎn)指向新節(jié)點(diǎn)
        pnew->pnext=NULL;   //新節(jié)點(diǎn)的指針為NULL
        printf("NO.%d: ",i+1);
        scanf("%s", pend->name);//輸入數(shù)據(jù)存到鏈表中
        scanf("%s", pend->adr);
        scanf("%d",&pend->tel);
        pend=pnew;  //賦值后指向尾節(jié)點(diǎn)
    }
    pnew=pnew->pnext;//指向NULL
    free(pnew);      //釋放pnew內(nèi)存
}
void save(char *filename)/*存到文件內(nèi)*/
{
    FILE *w;//文件指針
    if ((w = fopen(filename, "wb")) == NULL){   /*二進(jìn)制只寫打開文件*/
        printf("cannot open file\n");
        exit(1);
    }
    for (int i = 0; i < n; i++)  //鏈表數(shù)據(jù)循環(huán)輸入到文件里
    {
         fprintf(w,"%s ",phead->name);//數(shù)據(jù)存入到文件
         fprintf(w,"%s ",phead->adr);
         fprintf(w,"%d", phead->tel);
         fprintf(w,"%s","\r\n");//換行
         phead=phead->pnext;//指向下一個節(jié)點(diǎn)
    }
    fclose(w);	//關(guān)閉文件
}
void show(char *filename)/*輸出文件*/
{
    FILE *fp;//文件指針
    stu info[100];  //負(fù)責(zé)存放文件中的數(shù)據(jù),然后輸出
    if ((fp = fopen(filename, "rb")) == NULL){   /*二進(jìn)制只讀打開文件*/
        printf("cannot open file\n");
        exit(1);
    }
    for (int i = 0; i < n; i++)
    {
        fscanf(fp,"%s",&(info[i].name));//輸出數(shù)據(jù)到數(shù)組
        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);//輸出數(shù)據(jù)到屏幕
    }
    fclose(fp);/*關(guān)閉文件*/
}
 
int main(void)
{
    char filename[50];
    printf("How many ?:\n");
    scanf("%d", &n);		/*輸入學(xué)生數(shù)*/
    printf("please input filename: ");
    scanf("%s", filename); /*輸入文件所在路徑及名稱*/
    Create();       //調(diào)用函數(shù)建立鏈表
    save(filename); //調(diào)用函數(shù)存到文件
    free(phead);//釋放phead內(nèi)存
    show(filename); //調(diào)用函數(shù)輸出文件
    system("pause");
    return 0;
}

我嘗試過fread和fwrite的做法,但都失敗了。

到此這篇關(guān)于C語言實(shí)現(xiàn)鏈表與文件存取的示例代碼的文章就介紹到這了,更多相關(guān)C語言鏈表與文件存取內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言指針詳解及用法示例

    C語言指針詳解及用法示例

    這篇文章主要介紹了C語言指針詳解及用法示例,介紹了其相關(guān)概念,然后分享了幾種用法,具有一定參考價值。需要的朋友可以了解下。
    2017-11-11
  • C++中const、volatile、mutable使用方法小結(jié)

    C++中const、volatile、mutable使用方法小結(jié)

    這篇文章主要介紹了C++中const、volatile、mutable使用方法小結(jié),需要的朋友可以參考下
    2020-01-01
  • openCV實(shí)現(xiàn)圖像分割

    openCV實(shí)現(xiàn)圖像分割

    這篇文章主要為大家詳細(xì)介紹了openCV實(shí)現(xiàn)圖像分割,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • C語言解決百錢買百雞問題

    C語言解決百錢買百雞問題

    本文給大家分享的是一個經(jīng)典的算法(百元百雞)的C語言版的解決方法,使用的是比較偷懶的窮舉法,有需要的小伙伴可以參考下。
    2016-02-02
  • C++ LeetCode300最長遞增子序列

    C++ LeetCode300最長遞增子序列

    這篇文章主要為大家介紹了C++ LeetCode300最長遞增子序列示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • C語言實(shí)現(xiàn)掃雷游戲(初級版)

    C語言實(shí)現(xiàn)掃雷游戲(初級版)

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)掃雷游戲初級版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • C++全面覆蓋內(nèi)存管理知識講解

    C++全面覆蓋內(nèi)存管理知識講解

    本章主要介紹C語言與C++的內(nèi)存管理,以C++的內(nèi)存分布作為引入,介紹C++不同于C語言的內(nèi)存管理方式(new delete對比 malloc free),感興趣的朋友來看看吧
    2022-06-06
  • C++類型轉(zhuǎn)換和IO流操作處理教程

    C++類型轉(zhuǎn)換和IO流操作處理教程

    這篇文章主要給大家介紹了關(guān)于C++類型轉(zhuǎn)換和IO流操作處理的相關(guān)資料,標(biāo)準(zhǔn)C++為了加強(qiáng)類型轉(zhuǎn)換的可視性,引入了四種命名的強(qiáng)制類型轉(zhuǎn)換操作符,文中給出了詳細(xì)的代碼示例,需要的朋友可以參考下
    2023-08-08
  • 記錄一個C++在條件查詢時遇到的問題(推薦)

    記錄一個C++在條件查詢時遇到的問題(推薦)

    這篇文章主要介紹了記錄一個C++在條件查詢時遇到的問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • C語言實(shí)現(xiàn)簡單的計(jì)算器

    C語言實(shí)現(xiàn)簡單的計(jì)算器

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡單的計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-02-02

最新評論