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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

试验七

發(fā)布時(shí)間:2025/4/16 编程问答 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 试验七 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

partq1 驗(yàn)證性試驗(yàn)

// 從文本文件file1.dat中讀取數(shù)據(jù),找出最高分和最低分學(xué)生信息,并輸出在屏幕上 #include <stdio.h> #include <stdlib.h>#define N 10// 定義一個(gè)結(jié)構(gòu)體類型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 ) { // 如果打開失敗,則輸出錯(cuò)誤提示信息,然后退出程序 printf("fail to open file1.dat\n");exit(0);}stmax.score = 0; // 先假定最高分是0,后面如發(fā)現(xiàn)比當(dāng)前最高分還高的分?jǐn)?shù),就更新最高分 stmin.score = 100; // 先假定最低分是100分,后面如發(fā)現(xiàn)比當(dāng)前最低分更低的分?jǐn)?shù),就更新最低分 while( !feof(fp)) {fscanf(fp, "%d %s %d", &st.num, st.name, &st.score); // 從fp指定的文件中格式化讀取一個(gè)學(xué)生信息if(st.score > stmax.score)stmax = st;else if(st.score < stmin.score)stmin = st; } fclose(fp);printf("最高分學(xué)生信息: %5d%15s%5d\n", stmax.num, stmax.name, stmax.score);printf("最低分學(xué)生信息: %5d%15s%5d\n", stmin.num, stmin.name, stmin.score);return 0; }// 這是《C語言程序設(shè)計(jì)教程學(xué)習(xí)指導(dǎo)》「2.10 文件」中的實(shí)驗(yàn),細(xì)微處做了微調(diào) // 這個(gè)源代碼沒有考慮多個(gè)高分或多個(gè)低分的情形。

對比驗(yàn)證性實(shí)驗(yàn)3和驗(yàn)證性實(shí)驗(yàn)4的程序源碼及運(yùn)行結(jié)果,總結(jié)比較二進(jìn)制文件與文本文件的區(qū)別:主要區(qū)別是存儲數(shù)值型數(shù)據(jù)的形式不同

文本文件:數(shù)據(jù)流由一個(gè)個(gè)字符組成,每個(gè)字符均以ASCII代碼存儲,占一個(gè)字節(jié)

二進(jìn)制文件:數(shù)據(jù)流由二進(jìn)制字節(jié)代碼組成,將數(shù)據(jù)按其在內(nèi)存中的存儲形式存儲在文件中

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

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

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

總結(jié)最后一次實(shí)驗(yàn)結(jié)束了 想一想自己這一路學(xué)的很多 。也謝謝老師。

轉(zhuǎn)載于:https://www.cnblogs.com/hsc6/p/11080530.html

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

總結(jié)

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

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。