


下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、三級信息管理技術(shù)機(jī)試 -224( 總分: 100.00 ,做題時(shí)間: 90 分鐘 )、上機(jī)題( 總題數(shù): 1,分?jǐn)?shù): 100.00)1. 函數(shù) ReadDat() 實(shí)現(xiàn)從文件 in dat 中讀取一篇英文文章并將其存入到字符串?dāng)?shù)組 xx 中。請編制函數(shù) StrOL() ,其函數(shù)的功能是: 以行為單位對行中以空格或標(biāo)點(diǎn)符號為分隔的所有單詞進(jìn)行倒排。 最后把已處 理的字符串(應(yīng)不含標(biāo)點(diǎn)符號)仍按行重新存入字符串?dāng)?shù)組XX中,最后調(diào)用函數(shù) WriteDat()把結(jié)果xx輸出到文件 out.dat 中。例如:原文: You He MeI am s student 結(jié)果: Me He You studen
2、t a am I 原是數(shù)據(jù)文件存放的格式是:每行的寬度均小于 80 個(gè)字符,含標(biāo)點(diǎn)符號和空格。 注意:部分源程序給出如下:請勿改動(dòng)主函數(shù) main() 、讀數(shù)據(jù)函數(shù) ReadDat() 和輸出數(shù)據(jù)函數(shù) WriteDat() 的內(nèi)容。 試題源程序 #include < stdio h >#include < string . h >#include < conio h>#include < ctype h >char xx5080;int maxline=0;/* 文章的總行數(shù) */int ReadDat(void) ; void WriteDat
3、(void) ; void StrOL(void)void main()system("cls") ; if(ReadDat()printf(”數(shù)據(jù)文件IN . DAT不能打開!/n/007");return ;StrOL() ;WriteDat() ;int ReadDat(void)FILE*fp ;int i=0;char*P ; if(fp=fopen("IN DAT" , "r")=NULL)return 1;while(fgets(xxi , 80, fp)!=NULL)P=strchr(xxi , '/
4、n') ; if(p)*P=0 ; i+ :maxline=i ; fclose(fp) ;return 0 ;void WriteDat(void)FILE*fp ;int i ;system("cls") ; fp=fopen("OUT DAT", "w");for(i=0 ; i < maxline ; i+)printf("%s/n" ,xxi) ; fprintf(fp , "%s/n" ,xxi)fclose(fp) ;分?jǐn)?shù): 100.00 ) 正確答案: (void
5、StrOL(void)int i ,j ;thai :t80=0); /* 定義一個(gè) t 作為臨時(shí)存儲(chǔ)單元并初始化為 0)*/for(i=o ; i < maxline ; i 十+)/* 遍歷數(shù)組的每一行 */j=strlen(xxi)-1 ; /* 讓變量 j 指向字符串 xxi whne(j > =0) /*使用while循環(huán)使j從字符串xxi while(j> =0&& !isalpha(xxij)xxij=0; /* 將連續(xù)的非字母字符設(shè)為o*/j- ;if(j < 0)break :else if(t0!=0) /* 判斷 t 是否為空,為空
6、則說明 應(yīng)該為下一個(gè)單詞插入一個(gè)空格作為分隔符 */ strcat(t ,"") ; while(j > =0&& isalpha(xxij) j- ; /* 這個(gè) while 循環(huán)用于找到下一個(gè)單詞的開頭 strcat(t ,&xxij+1);/* 用 strcat 函數(shù)將找到的單詞連接到 t 的末尾 */的最后一個(gè)字符 */ 的最后一個(gè)字符遍歷到第一個(gè)字符 */t 中沒有存儲(chǔ)單詞,不必插入空格分隔符。反之則*/strcpy(xxi,t) ; /*while 循環(huán)結(jié)束,整行的單詞已經(jīng)倒排入臨時(shí)數(shù)組 t 中,根據(jù)題目要求此時(shí)應(yīng)使用strcpy 函數(shù)將 t 復(fù)制回?cái)?shù)組 xx 的當(dāng)前行 */t0=0 ; /* 臨時(shí)存儲(chǔ)數(shù)組要清空 */)解析: 解析 本題主要考查的是字符串排序問題。首先用for 循環(huán)對每一行遍歷,對于某一行 xxi 來說設(shè)置一個(gè)變量 j ,使用 while 循環(huán)從最后一個(gè)字符開始遍歷該行,在這個(gè)循環(huán)里再次使用第二個(gè) while 循 環(huán)來判斷是不是碰到連續(xù)的非字母,碰到則把該位置置為0,繼續(xù)往前掃描,若連續(xù)碰到字母字符則不作改動(dòng),直到碰到非字母字符,這樣就找到了一個(gè)單詞,將此單詞存入臨時(shí)數(shù)組變量 t 中,這樣一行掃描完 就把所有單詞倒序存入了 t 中,最后把 t 中的內(nèi)容復(fù)制給 xxi ,臨時(shí)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年虛擬現(xiàn)實(shí)技術(shù)在職業(yè)教育課程中的教學(xué)設(shè)計(jì)研究報(bào)告001
- 2025年醫(yī)院電子病歷系統(tǒng)在醫(yī)療大數(shù)據(jù)中的應(yīng)用與優(yōu)化報(bào)告
- 2025年醫(yī)院電子病歷系統(tǒng)優(yōu)化構(gòu)建醫(yī)療大數(shù)據(jù)分析平臺報(bào)告
- 終身學(xué)習(xí)視角下2025年成人教育體系構(gòu)建與平臺運(yùn)營的師資培訓(xùn)策略報(bào)告
- 2025年醫(yī)藥流通行業(yè)供應(yīng)鏈優(yōu)化與成本控制政策研究實(shí)踐報(bào)告
- 2025年醫(yī)藥流通行業(yè)供應(yīng)鏈優(yōu)化與成本控制案例分析報(bào)告
- 保安證考試題及答案
- 安全員c證試題及答案
- 安全試題及答案和解析
- 零售私域流量運(yùn)營的線上線下促銷活動(dòng)策劃報(bào)告
- 中年危機(jī)人生規(guī)劃
- 《風(fēng)電功率預(yù)測功能規(guī)范》
- 關(guān)于讀后續(xù)寫的可行操作課件-高三英語一輪復(fù)習(xí)
- 港口企業(yè)財(cái)務(wù)風(fēng)險(xiǎn)分析報(bào)告
- 2023年貴州黔西南州專項(xiàng)招聘國企業(yè)工作人員21人考前自測高頻難、易考點(diǎn)模擬試題(共500題)含答案詳解
- 中醫(yī)護(hù)理實(shí)訓(xùn)報(bào)告總結(jié)
- 動(dòng)畫制作與電影特效課件
- 監(jiān)理抽檢表 - 08橋梁工程
- 鼻息肉護(hù)理教學(xué)查房
- 小區(qū)交通安全應(yīng)急預(yù)案
- 2023年第四屆全國郵政行業(yè)職業(yè)技能競賽-全國總決賽理論知識試題及答案
評論
0/150
提交評論