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
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...