日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

试验七

發布時間:2025/4/16 编程问答 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 试验七 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

partq1 驗證性試驗

// 從文本文件file1.dat中讀取數據,找出最高分和最低分學生信息,并輸出在屏幕上 #include <stdio.h> #include <stdlib.h>#define N 10// 定義一個結構體類型STU typedef struct student {int num;char name[20];int score; }STU;int main() {STU st, stmax, stmin;int i;FILE *fp;// 以只讀文本方式打開文件file1.dat fp = fopen("file1.dat", "r");if( !fp ) { // 如果打開失敗,則輸出錯誤提示信息,然后退出程序 printf("fail to open file1.dat\n");exit(0);}stmax.score = 0; // 先假定最高分是0,后面如發現比當前最高分還高的分數,就更新最高分 stmin.score = 100; // 先假定最低分是100分,后面如發現比當前最低分更低的分數,就更新最低分 while( !feof(fp)) {fscanf(fp, "%d %s %d", &st.num, st.name, &st.score); // 從fp指定的文件中格式化讀取一個學生信息if(st.score > stmax.score)stmax = st;else if(st.score < stmin.score)stmin = st; } fclose(fp);printf("最高分學生信息: %5d%15s%5d\n", stmax.num, stmax.name, stmax.score);printf("最低分學生信息: %5d%15s%5d\n", stmin.num, stmin.name, stmin.score);return 0; }// 這是《C語言程序設計教程學習指導》「2.10 文件」中的實驗,細微處做了微調 // 這個源代碼沒有考慮多個高分或多個低分的情形。

對比驗證性實驗3和驗證性實驗4的程序源碼及運行結果,總結比較二進制文件與文本文件的區別:主要區別是存儲數值型數據的形式不同

文本文件:數據流由一個個字符組成,每個字符均以ASCII代碼存儲,占一個字節

二進制文件:數據流由二進制字節代碼組成,將數據按其在內存中的存儲形式存儲在文件中

3寫一個簡單的程序,嘗試從二進制文件?le4.dat中讀出數據,并在屏幕上顯示,以此查看文件?le4.dat的內 容。

// 從文本數據文件file1.dat中讀入數據,按成績從高到低排序,將排序結果輸出到屏幕上,同時以文本方式存入文件file3.dat中。 #include <stdio.h> #include <stdlib.h>#define N 10// 定義一個結構體類型STU typedef struct student {int num;char name[20];int score; }STU;void sort(STU *pst, int n); // 函數聲明int main() {FILE *fin, *fout;STU st[N];int i;// 以只讀文本方式打開文件file1.datfin = fopen("file1.dat", "r");if( !fin ) { // 如果打開失敗,則輸出錯誤提示信息,然后退出程序printf("fail to open file1.dat\n");exit(0);}// 從fin指向的數據文件file1.dat中讀取數據到結構體數組stfor(i=0; i<N; i++)fscanf(fin, "%d %s %d", &st[i].num, st[i].name, &st[i].score);fclose(fin); // 關閉fin指向的文件file1.dat// 調用函數sort()對數組st中數據,按分數又高到低排序 sort(st, N);// 以寫方式打開/創建文本文件file3.datfout = fopen("file3.dat", "w");if( !fout ) { // 如果打開失敗,則輸出錯誤提示信息,然后退出程序printf("fail to open file1.dat\n");exit(0);}// 將排序后的數組st中數據輸出到屏幕,同時,也寫入文件file3.datfor(i=0; i<N; i++) {printf("%-6d%-10s%3d\n", st[i].num, st[i].name, st[i].score);fprintf(fout, "%-6d%-10s%3d\n", st[i].num, st[i].name, st[i].score);}fclose(fout); // 關閉fout指向的文件file3.datreturn 0; }// 函數功能描述:對pst指向的n個STU結構體數據進行排序,按成績數據項由高到底排序 // 排序算法:冒泡法 void sort(STU *pst, int n) {STU *pi, *pj, t;for(pi = pst; pi < pst+n-1; pi++)for(pj = pi+1; pj < pst+n; pj++)if(pi->score < pj->score) {t = *pi;*pi = *pj;*pj = t;}}

part2

// 從文本數據文件file1.dat中讀入數據,按成績從高到低排序,將排序結果輸出到屏幕上,同時以文本方式存入文件file3.dat中。 #include <stdio.h> #include <stdlib.h>#define N 10// 定義一個結構體類型STU typedef struct student {int num;char name[20];int score; }STU;void sort(STU *pst, int n); // 函數聲明int main() {FILE *fin, *fout;STU st[N];int i;// 以只讀文本方式打開文件file1.datfin = fopen("file1.dat", "r");if( !fin ) { // 如果打開失敗,則輸出錯誤提示信息,然后退出程序printf("fail to open file1.dat\n");exit(0);}// 從fin指向的數據文件file1.dat中讀取數據到結構體數組stfor(i=0; i<N; i++)fscanf(fin, "%d %s %d", &st[i].num, st[i].name, &st[i].score);fclose(fin); // 關閉fin指向的文件file1.dat// 調用函數sort()對數組st中數據,按分數又高到低排序 sort(st, N);// 以寫方式打開/創建文本文件file3.datfout = fopen("file3.dat", "w");if( !fout ) { // 如果打開失敗,則輸出錯誤提示信息,然后退出程序printf("fail to open file1.dat\n");exit(0);}// 將排序后的數組st中數據輸出到屏幕,同時,也寫入文件file3.datfor(i=0; i<N; i++) {printf("%-6d%-10s%3d\n", st[i].num, st[i].name, st[i].score);fprintf(fout, "%-6d%-10s%3d\n", st[i].num, st[i].name, st[i].score);}fclose(fout); // 關閉fout指向的文件file3.datreturn 0; }// 函數功能描述:對pst指向的n個STU結構體數據進行排序,按成績數據項由高到底排序 // 排序算法:冒泡法 void sort(STU *pst, int n) {STU *pi, *pj, t;for(pi = pst; pi < pst+n-1; pi++)for(pj = pi+1; pj < pst+n; pj++)if(pi->score < pj->score) {t = *pi;*pi = *pj;*pj = t;}}

總結最后一次實驗結束了 想一想自己這一路學的很多 。也謝謝老師。

轉載于:https://www.cnblogs.com/hsc6/p/11080530.html

《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

總結

以上是生活随笔為你收集整理的试验七的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。