C程式設計(譚浩強)第五版課後題答案 第十章

来源:https://www.cnblogs.com/lazyheartkx/archive/2022/05/18/16285479.html
-Advertisement-
Play Games

大家好,這篇文章分享了C程式設計(譚浩強)第五版第十章課後題答案,所有程式已經測試能夠正常運行,如果小伙伴發現有錯誤的的地方,歡迎留言告訴我,我會及時改正!感謝大家的觀看!!! ...


1.什麼是文件型指針?通過文件指針訪問文件有什麼好處?

答:緩衝文件系統中,關鍵的概念是“文件類型指針”,簡稱“文件指針”。每個被使用的文件都在記憶體中開闢一個相應的文件信息區,用來存放文件的有關信息(如文件的名字、文件狀態及文件當前位置等)。這些信息是保存在一個結構體變數中的。該結構體類型是由系統聲明的,取名為FILE。

通過文件指針訪問文件的好處是:可以隨機訪問文件,有效表示數據結構,動態分配記憶體,方便使用字元串,有效使用數組。

 

2.對文件的打開與關閉的含義是什麼?為什麼要打開和關閉文件?

答:”打開“是指為文件建立相應的信息區(用來存放有關文件的信息)和文件緩衝區(用來暫時存放輸入輸出的數據)。

”關閉“是指撤銷文件信息區和文件緩衝區,使文件指針變數不再指向該文件,顯然就無法進行對文件的讀寫了。

 

3.從鍵盤輸入一個字元串,將其中的小寫字母全部轉換成大寫字母,然後輸出到一個磁碟文件test中保存,輸入的字元串以“!”結束。

 

#include <stdio.h>
#include<string.h>
#include<stdlib.h>
int main(void)
{
    FILE *fp;
    char str[100];
    int i=0;
    if((fp=fopen("text","w"))==NULL)
    {
        printf("open file text error!\n");
        exit(0);
    }
    printf("請輸入字元串:\n");
    gets(str);
    while(str[i]!='!')
    {
        if(str[i]>='a' && str[i]<='z')
            str[i]=str[i]-'a' + 'A';
        fputc(str[i],fp);
        i++;
    }
    fclose(fp);
    fp=fopen("text","r");
    fgets(str,strlen(str)+1,fp);
    printf("%s\n",str);
    fclose(fp);
    return 0;
}

 

4.有兩個磁碟文件A和B,各存放一行字母,今要求把這兩個文件中的信息合併(按字母順序排列),輸出到一個新文件C中去。

#include <stdio.h>
#include<stdlib.h>
#include<string.h>
int main(void)
{
    FILE *fa,*fb,*fc;
    char a[1024]={0};
    int len=strlen(a);
    void select_sort(char *);

    fa=fopen("A","r");
    fb=fopen("B","r");
    fc=fopen("C","w");

    fgets(a,1024,fa);            //從指定的流 fa 讀取一行,並把它存儲在 a 所指向的字元串內。
    fgets(a+len,1024-len,fb);    //當讀取 (1024-1) 個字元時,或者讀取到換行符時,或者到達文件末尾時,它會停止,
    select_sort(a);
    fputs(a,fc);

    fclose(fa);
    fclose(fb);
    fclose(fc);
}
void select_sort(char *str)
{
    int i,j,min;
    int len=strlen(str);
    void swap(char *,int,int);
    for(i=0;i<len;i++)
    {
        min=i;
        for(j=i+1;j<len;j++)
        {
            if(str[j]<str[min])
                min=j;
        }
        swap(str,min,j);
    }
}
void swap(char *str,int i,int j)
{
    char t=str[i];
    str[i]=str[j];
    str[j]=t;
}

 

5.有5個學生,每個學生有3門課程的成績,從鍵盤輸入學生數據(包括學號,姓名,3門課程成績),計算出平均成績,將原有數據和計算出的平均分數存放在磁碟文件stud中。

#include <stdio.h>
#include<stdlib.h>

struct student {
    int num;
    char name[40];
    int score[3];
    float avg;
};

int main(void)
{
    int i;
    struct student stu[5];
    FILE *fp=NULL;
    printf("按以下格式輸入各名同學的成績\n");
    printf("num name score1 score2 score3\n");
    for(i=0;i<5;i++)
    {
        scanf("%d%s%d%f",&stu[i].num,&stu[i].name,&stu[i].score[0],&stu[i].score[1],&stu[i].score[2]);
        stu[i].avg=(stu[i].score[0]+stu[i].score[1]+stu[i].score[2])/3.0;
    }

    if((fp=fopen("stud","wb"))==NULL)
    {
        printf("open file stu for write error\n");
        exit(0);
    }

    if(fwrite(stu,sizeof(stu),1,fp)!=1)            //將緩衝區stu中的內容寫到流fp中,每塊的大小為sizeof(stu),塊數為1,返回值為實際寫出塊數
    {
        printf("write error!\n");
        return 1;
    }
    fclose(fp);
}

 

6.將第5題stud文件中的學生數據,按平均分進行排序處理,將已排序的學生數據存入一個新文件stu_ sort 中。

#include <stdio.h>
#include<stdlib.h>

struct student {
    int num;
    char name[40];
    int score[3];
    float avg;
};

int main(void)
{
    struct student stu[5];
    void sort(struct student[],int);
    FILE *fp,*fw;
    fp=NULL;

    if((fp=fopen("stud","rb"))==NULL)
    {
        printf("open file stu for write error\n");
        exit(0);
    }

    if(fread(stu,sizeof(stu),1,fp)!=1)        //從流fp中讀取內容寫到緩衝區stu中,每塊的大小為sizeof(stu),塊數為1,返回值為實際寫出塊數
    {
        printf("write error!\n");
        return 1;
    }
    fclose(fp);

    sort(stu,5);

    fw=fopen("stu_sort","wb");
    fwrite(stu,sizeof(stu),1,fw);
    fclose(fw);
    return 0;
}

void sort(struct student stu[],int len)
{
    int i,j,min;
    struct student temp;
    for(i=0;i<len;i++)
    {
        min=i;
        for(j=i+1;j<len;j++)
        {
            if(stu[j].avg<stu[min].avg)
                min=j;
        }
        temp=stu[min];
        stu[min]=stu[i];
        stu[i]=temp;
    }
}

 

7.將第6題已排序的學生成績文件進行插入處理。插入一個學生的3門課程成績,程式先計算新插入學生的平均成績,然後將它按成績高低順序插入,插入後建立一個新文件。

#include <stdio.h>
#include<stdlib.h>
#include<string.h>
struct student {
    int num;
    char name[40];
    int score[3];
    float avg;
};

int main(void)
{
    struct student stu[5];
    struct student new_stu[6];
    
    void sort(struct student[],int);
    FILE *fp,*fw;
    fp=NULL;

    if((fp=fopen("stud","rb"))==NULL)
    {
        printf("open file stu for write error\n");
        exit(0);
    }

    if(fread(stu,sizeof(stu),1,fp)!=1)
    {
        printf("read error!\n");
        return 1;
    }
    fclose(fp);

    memcpy(new_stu,stu,sizeof(stu));
    printf("請按以下格式輸入第6名同學的信息\n");
    printf("num name score1 score2 score3\n");
    scanf("%d %s %d %d %d",&new_stu[5].num,&new_stu[5].name,&new_stu[5].score[0],&new_stu[5].score[1],&new_stu[5].score[2]);
    new_stu[5].avg=(new_stu[5].score[0]+new_stu[5].score[1]+new_stu[5].score[2])/3.0;

    sort(new_stu,6);

    fw=fopen("tmp_sort","wb");
    fwrite(new_stu,sizeof(new_stu),1,fw);
    fclose(fw);
    return 0;
}

void sort(struct student stu[],int len)
{
    int i,j,min;
    struct student temp;
    for(i=0;i<len;i++)
    {
        min=i;
        for(j=i+1;j<len;j++)
        {
            if(stu[j].avg<stu[min].avg)
                min=j;
        }
        temp=stu[min];
        stu[min]=stu[i];
        stu[i]=temp;
    }
}

 

8.將第7題結果仍存入原有的stu_sort 文件而不另建立新文件。

 

#include <stdio.h>
#include<stdlib.h>
#include<string.h>
struct student {
    int num;
    char name[40];
    int score[3];
    float avg;
};

int main(void)
{
    struct student stu[6];
    FILE *fp,*fw;
    fp=NULL;

    if((fp=fopen("stud","rb"))==NULL)
    {
        printf("open file stu for write error\n");
        exit(0);
    }

    if(fread(stu,sizeof(stu),1,fp)!=1)
    {
        printf("read error!\n");
        return 1;
    }
    fclose(fp);


    fw=fopen("stu_sort","wb");
    fwrite(stu,sizeof(stu),1,fw);
    fclose(fw);
    return 0;
}

 

9.有一磁碟文件employee,記憶體放職工的數據。每個職工的數據包括職工姓名、職工號、性別、年齡、住址、工資、健康狀況、文化程度。今要求將職工名、工資的信息單獨抽出來另建一個簡明的職工工資文件。

#include <stdio.h>
#include<stdlib.h>
#include<string.h>

struct employee {
    int num;
    char name[40];
    char sex[4];
    int age;
    char addr[80];
    int salary;
    char health[10];
    char clas[10];
};
struct nasa{
    char name[40];
    int salary;
};

int main(void)
{
    int i;
    FILE *fp1,*fp2;
    struct employee employee_n1[5];
    struct nasa nasa_n2[5];
    
    fp1=open("employee","rb");
    fread(employee_n1,sizeof(employee_n1),1,fp1);
    fclose(fp1);

    for(i=0;i<5;i++)
    {
        strcpy(nasa_n2[i].name,employee_n1[i].name);
        nasa_n2[i].salary=employee_n1[i].salary;
    }

    fp2=open("nasa","rb");
    fwrite(nasa_n2,sizeof(nasa_n2),1,fp2);
    fclose(fp2);
    return 0;
}

 

10.從第9題的“職工工資文件”中刪去一個職工的數據,再存回原文件。

#include <stdio.h>
#include<stdlib.h>
#include<string.h>

struct nasa{
    char name[40];
    int salary;
};

int main(void)
{
    int i;
    FILE *fp;
    struct nasa nasa_n[5];
    char name[40];
    
    fp=open("nasa","rb");
    fwrite(nasa_n,sizeof(nasa_n),1,fp);
    fclose(fp);

    printf("請輸入要刪去的名字:\n");
    scanf("%s",name);
    fp=open("nasa","wb");
    for(i=0;i<5;i++)
    {
        if(strcmp(nasa_n[i].name,name)==0)
            continue;
        fwrite(&nasa_n,sizeof(nasa_n),1,fp);
    }
    fclose(fp);
    return 0;
}

 

11.從鍵盤輸入若幹行字元(每行長度不等),輸入後把它們存儲到一磁碟文件中。再從該文件中讀入這些數據,將其中小寫字母轉換成大寫字母後在顯示屏上輸出。

#include<stdio.h>
#include<stdlib.h>

int main()
{
    int i,flag;
    char str[80],c;
    FILE *fp;
    fp=fopen("text.txt","w");        //註意fopen寫成open了不會報錯,但會運行崩潰
    flag=1;
    while(flag==1)
    {
        printf("Input string:");
        gets(str);
        fprintf(fp,"%s",str);                //把字元串str按%s的格式輸出到fp指向的文件text中 
        printf("輸入N或結束迴圈,輸入其他字元結束迴圈:");
        c=getchar();
        getchar();                    //吸收回車產生的換行符 
        if((c=='N')||(c=='n'))
            flag=0;
        printf("\n");
    }
    fclose(fp);
    fp=fopen("text.txt","r");
    printf("轉換後的字元串為:");
    while(fscanf(fp,"%s",str)!=EOF)            //從fp指向的磁碟文件text中讀取字元串送給字元串str 
    {
        for(i=0;str[i]!='\0';i++)
        {
            if((str[i]>='a')&& (str[i]<='z'))            
                str[i]=str[i]-32;                
        }
        printf("%s",str);
    }
    printf("\n");
   fclose(fp);
   return 0;
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本章是系列文章的第三章,介紹了基於數據流分析的一些優化方法。包括生命周期管理,可獲得表達式,常用表達式,可達性定義。本章在介紹這4中分析方法的基礎上提取出它們的通用模式。這一章形式化的內容比較多,看的時候有點燒腦,最好自己手工推導一下,要不然基本上看不懂:) 本文中的所有內容來自學習DCC888的學 ...
  • 一、吐槽 已經是凌晨12點了我還是睡不著 我所有的實體類時間用的j8的LocalDateTime 這就導致一個問題:jackson不能序列化時間,因為它不支持j8的Api,讓我添加 jackson-datatype-jsr310 解決 二、問題 如果是這樣做統一返回結果集需要 private sta ...
  • 知識回顧 解析完Bean信息的合併,可以知道Spring在實例化Bean之後,屬性填充前,對Bean進行了Bean的合併操作,這裡的操作主要做了對Bean對象標記了@Autowired、@Value、@Resource、@PostConstruct、@PreDestroy註解的欄位或者方法進行解析, ...
  • Cookied的設置會造成XSS攻擊,所以出現了防禦機制HttpOnly標誌(可選),客戶端腳本將無法訪問cookie(如果瀏覽器支持該標誌的話)。因此即使客戶端存在跨站點腳本(XSS)漏洞,瀏覽器也不會將Cookie透露給第三方。Cookie和Session後面還會設計到xss和csrf漏洞的利用... ...
  • 為了修複生產數據,需要執行一段一次性的代碼。 鑒於是spring老項目,就想到了InitializingBean。 代碼如下。服務啟動後,log里發現出現2條“一次性任務開始”。 好在裡面邏輯做了防重控制,沒有受到什麼影響。 @Slf4j @Component public class TransT ...
  • 什麼是隱藏類 隱藏類,是一種不能被其他類直接使用的類。引入隱藏類的主要目的是給框架來使用,使得框架可以在運行時生成類,並通過反射間接使用它們。可能有點抽象,不要緊,下麵我們通過一個例子來直觀的認識它! 隱藏類案例 第一步:先創建一個普通的Java類 public class JEP371Hidden ...
  • 下麵介紹的是JUC包下一些線程安全類的一些簡單使用和一些小demo。 Semaphore 信號量,即可以同時使用的線程數,tryrequire就是將信號量減一,release就是信號量+1,當等於0就會阻塞,大於零才會喚醒。 當需要控制線程訪問數量,可以使用信號量來做控制,比較簡單。 下麵是使用信號 ...
  • Spring Ioc源碼分析系列--Ioc容器註冊BeanPostProcessor後置處理器以及事件消息處理 前言 上一篇分析了BeanFactoryPostProcessor的作用,那麼這一篇繼續在refresh()方法里游蕩,相信對Spring熟悉點的朋友,在看完BeanFactoryPost ...
一周排行
    -Advertisement-
    Play Games
  • 1. 說明 /* Performs operations on System.String instances that contain file or directory path information. These operations are performed in a cross-pla ...
  • 視頻地址:【WebApi+Vue3從0到1搭建《許可權管理系統》系列視頻:搭建JWT系統鑒權-嗶哩嗶哩】 https://b23.tv/R6cOcDO qq群:801913255 一、在appsettings.json中設置鑒權屬性 /*jwt鑒權*/ "JwtSetting": { "Issuer" ...
  • 引言 集成測試可在包含應用支持基礎結構(如資料庫、文件系統和網路)的級別上確保應用組件功能正常。 ASP.NET Core 通過將單元測試框架與測試 Web 主機和記憶體中測試伺服器結合使用來支持集成測試。 簡介 集成測試與單元測試相比,能夠在更廣泛的級別上評估應用的組件,確認多個組件一起工作以生成預 ...
  • 在.NET Emit編程中,我們探討了運算操作指令的重要性和應用。這些指令包括各種數學運算、位操作和比較操作,能夠在動態生成的代碼中實現對數據的處理和操作。通過這些指令,開發人員可以靈活地進行算術運算、邏輯運算和比較操作,從而實現各種複雜的演算法和邏輯......本篇之後,將進入第七部分:實戰項目 ...
  • 前言 多表頭表格是一個常見的業務需求,然而WPF中卻沒有預設實現這個功能,得益於WPF強大的控制項模板設計,我們可以通過修改控制項模板的方式自己實現它。 一、需求分析 下圖為一個典型的統計表格,統計1-12月的數據。 此時我們有一個需求,需要將月份按季度劃分,以便能夠直觀地看到季度統計數據,以下為該需求 ...
  • 如何將 ASP.NET Core MVC 項目的視圖分離到另一個項目 在當下這個年代 SPA 已是主流,人們早已忘記了 MVC 以及 Razor 的故事。但是在某些場景下 SSR 還是有意想不到效果。比如某些靜態頁面,比如追求首屏載入速度的時候。最近在項目中回歸傳統效果還是不錯。 有的時候我們希望將 ...
  • System.AggregateException: 發生一個或多個錯誤。 > Microsoft.WebTools.Shared.Exceptions.WebToolsException: 生成失敗。檢查輸出視窗瞭解更多詳細信息。 內部異常堆棧跟蹤的結尾 > (內部異常 #0) Microsoft ...
  • 引言 在上一章節我們實戰了在Asp.Net Core中的項目實戰,這一章節講解一下如何測試Asp.Net Core的中間件。 TestServer 還記得我們在集成測試中提供的TestServer嗎? TestServer 是由 Microsoft.AspNetCore.TestHost 包提供的。 ...
  • 在發現結果為真的WHEN子句時,CASE表達式的真假值判斷會終止,剩餘的WHEN子句會被忽略: CASE WHEN col_1 IN ('a', 'b') THEN '第一' WHEN col_1 IN ('a') THEN '第二' ELSE '其他' END 註意: 統一各分支返回的數據類型. ...
  • 在C#編程世界中,語法的精妙之處往往體現在那些看似微小卻極具影響力的符號與結構之中。其中,“_ =” 這一組合突然出現還真不知道什麼意思。本文將深入剖析“_ =” 的含義、工作原理及其在實際編程中的廣泛應用,揭示其作為C#語法奇兵的重要角色。 一、下劃線 _:神秘的棄元符號 下劃線 _ 在C#中並非 ...