2013年9月計算機三級數(shù)據(jù)庫上機題庫_第1頁
2013年9月計算機三級數(shù)據(jù)庫上機題庫_第2頁
2013年9月計算機三級數(shù)據(jù)庫上機題庫_第3頁
2013年9月計算機三級數(shù)據(jù)庫上機題庫_第4頁
已閱讀5頁,還剩286頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

計算機三級數(shù)據(jù)庫上機題庫1.調(diào)用函數(shù)rwdata(),從IN.dat文件中讀取10組數(shù)據(jù)(m和k值),并嵌套調(diào)用primenum函數(shù)分別得出array口數(shù)組。請編寫函數(shù)primenum(intm,intk,intarray[]),該函數(shù)的功能是:將緊靠m的k個素數(shù)存入數(shù)組array并在屏幕上顯示。最后把結(jié)果輸出到文件OUT.dat中。例如,若輸入39,則應輸出5711131719232931。注意:部分程序已經(jīng)給出。請勿改動主函數(shù)main。利輸出數(shù)據(jù)函數(shù)rwdata()的內(nèi)容。#include<conio.h>#include<stdio.h>voidrwdata();voidprimenum(intm,intk,intarray[])main(){intm,n,array[1000];printf(H\nPleaseentertwointegers:'*);scanf(**%d%d*,,&m,&n);primenum(m,n,array);for(m=0;m<n;m++)printf(*'%d**,array[m]);printf(n\n**);rwdata();}voidrwdata(){intm,n,array[1000],i;FILE*readfile,*writefile;readfile=fopen(**in.dat**,*,r**);writefile=fopen(',out.dat*',*,w**);{fscanf(readfile,'1%d%dM,&m,&n);primenum(m,n,array);for(m=0;m<n;m++)fprintf(writefile,*'%d二array[m]);fprintf(writefile,H\nM);)fclose(readfile);fclose(writefile);【知識點播】素數(shù)的定義:如果ー個數(shù)的正因子只有1和這個數(shù)本身,那么這個數(shù)就是素數(shù)?!绢}目分析】分析題目可知,題中需要解決的問題就是Primenum函數(shù)的功能問題(rwdata函數(shù)功能題中已經(jīng)給出),而Primenum函數(shù)的功能是求在指定數(shù)m之后的k個素數(shù),因此本題的關鍵在于如何判斷ー個數(shù)是素數(shù),之后就可以通過ー個for循環(huán)來求得在m之后的k個素數(shù)了。【解題思路】根據(jù)素數(shù)的定義,本題采用的算法是:首先定義ー個變量Value,并把m之后的數(shù)逐個賦值給該變量;然后用2-value/2數(shù)除value?如果value能被2?value/2之中的任何ー個整數(shù)整除,則value不是素數(shù),結(jié)束循環(huán);如果value不能被2?value/2之間的任一?整數(shù)整除,則退出循環(huán),然后判斷循環(huán)變量i是否大于value/2,如果大于,則value是素數(shù),并將value值賦給array[川,然后n++;再判斷n是否大于等于k,如果大于等于k,就完成了程序要求的功能,退出循環(huán),否則value加1,根據(jù)以上算法繼續(xù)進行?!敬鸢浮縱oidprimenum(intm,intk,intarray[]){intvalue=m+1;inthalf,n=0,i;while(l){half=value/2;for(i=2;i<=half;i++)if(value%i==0)break;if(i>halD{array[n]=value;n++;)if(n>=k)break;value++;)}【容錯分析】判斷ー個數(shù)m(大于1)是否素數(shù)的簡單的算法:枚舉2到m/2之間的整數(shù),看能否被m整除,如果能整除,就不是素數(shù),否則是素數(shù)。2.在文件IN.dat中有200個正整數(shù),且每個數(shù)均在!000-9999之間。函數(shù)RData()讀取這200個數(shù)存放到數(shù)組original中。請編寫函數(shù)numAscend。,其功能是:要求按每個數(shù)的后3位的大小進行升序排列,然后取出滿足此條件的前10個數(shù)依次存入數(shù)組result中,如果后3位的數(shù)值相等,則按原先的數(shù)值進行降序排列。最后調(diào)用函數(shù)WData(),把結(jié)果result輸出到文件OUT.dat中。例如,處理前:60125099901270258088處理后:90126012702580885099注意:部分程序已給出。請勿改動主函數(shù)main。、讀數(shù)據(jù)函數(shù)RData()和輸出數(shù)據(jù)函數(shù)WData()的內(nèi)容。#include<stdio.h>#include<string.h>#include<conio.h>intoriginal[200],result[10];voidnumascend()voidRData(){FILE*in;inti;in=fopen(,,IN.dat",nrM);for(i=0;i<200;i++)fscanf(in,"%d」,&original[i]);fclose(in);1voidWData(){FILE*out;inti;out=fopen("〇UT.da口”w");for(i=0;i<10;i++){printf(M%d",result[i]);fprintf(out,M%d\nM,result[i]);)fclose(out);}voidmain(){RData();numascend();WData();【題目分析】首先我們來看看題中要求我們解決的問題有哪些。①按。riginal數(shù)組中各元素數(shù)字的后3位數(shù)的大小進行升序排列,如果數(shù)值相等,則按原先的數(shù)值進行降序排列;②取出排序后的original數(shù)組中的前10個數(shù)依次存入result數(shù)組中?!窘忸}思路】根據(jù)上面的分析,編寫程序有以下幾個步驟:第1步:首先分解出數(shù)組中兩個元素的后三位,這里采用在兩次循環(huán)中求出正整數(shù)original[i]和original[j]Xt1000的余數(shù)的方法;第2步:然后比較兩個數(shù)余數(shù)的大小,如果正整數(shù)original[i]和originalfj]對1000的余數(shù)不相同,則按照升序進行排序,如果相同,則比較original[i]和original5的大小,按照降序進行排序;第3步:利用ー個for循環(huán)語句把original數(shù)組中的前10個數(shù)輸出給result數(shù)組?!敬鸢浮縱oidnumascend(){inti,j,data;for(i=0;i<199;i++)for(j=i+1;j<200;j++){if(original[i]%1000>original。]%1000){data=original[i];original[i]=original|j];original[j]=data;}elseif(original[i]%1000==originalfj]%100〇){if(original[i]<original[j]){data=originalIi];originalfi]=original[j];originallj]=data;)})for(i=0;i<10;i++)result[i]=original[i];

容錯分析:數(shù)組original[i]中兩個數(shù)的位置交換要借助中間變量data。3.已知文件IN.dat中存有100個產(chǎn)品銷售記錄,毎個產(chǎn)品銷售記錄由產(chǎn)品代碼code(字符型4位)、產(chǎn)品名稱name(字符型10位)、騷uprice(整型)、數(shù)量amount(整型)、金額sum(長整型)5部分組成。其中:金額=單價X數(shù)量。函數(shù)RData()讀取這100個銷售記錄并存入結(jié)構數(shù)組sell中。請編寫函數(shù)DescSort(),其功能要求:按產(chǎn)品代碼從大到小進行排列,若產(chǎn)品代碼相同,則按金額從大到小進行排列,最終排列結(jié)果仍存入結(jié)構數(shù)組sell中,最后調(diào)用函數(shù)WData(),把結(jié)果輸出到文件OUT.dat中。注意:部分程序已給出。請勿改動キ:函數(shù)main。、讀數(shù)據(jù)函數(shù)RData()和輸出數(shù)據(jù)函數(shù)WData()的內(nèi)容。#include<stdio.h>#include<string.h>#include<conio.h>#include<stdlib.h>#defineMAX100typedefstructcharcode[5];/charcode[5];/?產(chǎn)品代碼?/charname[l1];charname[l1];/?產(chǎn)品名稱?/intuprice;/intuprice;/?單價*/intamount;/intamount;/?數(shù)量?/longsum;/longsum;/?金額?/1PRO;PROsell[MAX];voidRData();voidWData();voidDescSort()voidmain(){memset(sell,0,sizeof(sell));RData();DescSort();WData();)voidRData(){FILE*fp;charstr[80],ch[l1];inti;fp=fopen("IN.da「ヤ);for(i=0;i<100;i++){fgets(str,80,fp);memcpy(sell[i].code,str,4);memcpy(sell[i].name,str+4,10);memcpy(ch,str+14,4);ch[4]=0;sell[i].uprice=atoi(ch);memcpy(ch,str+18,5);ch[5]=0;sellfi].amount=atoi(ch);sell[i].sum=(long)sell[i].uprice*sell[i].amount;)fclose(fp);voidWData(void){FILE*fp;inti;fp=fopen("〇UT.da口W);for(i=0;i<100;i++){printf("%s%s%4d%5d%5d\n”,sell[i].code,sell[i].name,sell[i].uprice,sell[i].amount,sell[i].sum);fprintf(fp,n%s%s%4d%5d%5d\n",sell[i].code,sell[i].name,sell[i].uprice,sell[i].amount,sell[i].sum);)fclose(fp);}【題目分析】首先我們來看看題中要求我們解決的問題有哪些。①按產(chǎn)品代碼從大到小進行排列,若產(chǎn)品代碼相同,則按金額從大到小進行排列;②將排列結(jié)果存入結(jié)構數(shù)組sell中。分析題目可知,本題中使用結(jié)構數(shù)組sell來保存銷售記錄。產(chǎn)品代碼存儲在sell結(jié)構數(shù)組中的code成員中,金額存儲在sum成員中。【解題思路】我們可以利用兩個for循環(huán)結(jié)構對產(chǎn)品銷售記錄(strcmp(se叩].code,seUm.code))兩兩進行循環(huán)比較,如果這個表達式返回結(jié)果值小于〇,則進行兩個數(shù)據(jù)的交換,實現(xiàn)產(chǎn)品代碼從大到小進行排序。如果上面的表達式的返回值等于0,說明這兩個產(chǎn)品的代碼相同,則比較sell[i].sum與比l[j].sum的值。如果sell[i].sumvsell|j].sum,則進行兩個數(shù)據(jù)的交換,實現(xiàn)金額從大到小進行排序?!敬鸢浮縱oidDescSort(){inti,j;PROtemp;for(i=0;i<99;i++)for(j=i+l;j<100;j++)if(strcmp(sell[i].code,sellfjj.code)<0)temp=sell[i];sell[i]=selig];sell[j]=temp;1elseif(strcmp(sell[i].code,sell[j].code)==0){if(sell[i].sum<sell[j].sum){temp=sell[i];sell[i]=sell|j];sell[j]=temp;}}}容錯分析:數(shù)組sell[i]中兩個數(shù)的位置交換要借助中間變量tempo4.函數(shù)RData()實現(xiàn)從文件IN.dat中讀取ー篇英文文章,存入到字符串數(shù)組str中;請編寫encryptChar()函數(shù),其功能是:按給定的替代關系對數(shù)組str中的所有字符進行替代,仍存入數(shù)組str對應的位置上,最后調(diào)用函數(shù)WData(),把結(jié)果str輸出到文件OUT.dat中。替代關系:f(p)=p*llmod256(p是數(shù)組中某ー個字符的ASCII值,f(p)是計算后新字符的ASCI!值),如果計算后f(p)值小于1等于32或大于130,則該字符不變,否則將f(p)所對應的字符進行替代。原始數(shù)據(jù)文件存放的格式是:每行的寬度均小于80個字符。注意:部分程序已給出。請勿改動主函數(shù)main。、讀數(shù)據(jù)函數(shù)RData()和輸出數(shù)據(jù)函數(shù)WData()的內(nèi)容。#include<stdio.h>#include<string.h>#include<conio.h>#include<clype.h>unsignedcharstr[50][80];intmaxline=0;/?文章的總行數(shù)?/intRData(void);voidWData(void);voidencryptChar()voidmain(){if(RData()){ printf("數(shù)據(jù)文件IN.dat不能打開!\n\007");return;)encryptChar();WData();)intRData(void){FILE*fp;inti=0;unsignedchar*p;if((fp=fopen(MIN.dat",nrn))==NULL)return1;while(fgets(str[i],80,fp)!=NULL){p=strchr(str[i],5);if(P)*p=0;i++;)maxline=i;fclose(fp);return0;)voidWData(void){FILE*fp;inti;fp=fopen("〇UT.daロ”w“);for(i=0;i<maxline;i++){printf(M%s\nH,str[i]);fprintf(fp,H%s\nM,str[i]);)fclose(fp);)【題目分析】分析題目可知,題中需要解決的問題就是實現(xiàn)encryptChar函數(shù)的功能問題,而encryptChar函數(shù)的功能是:實現(xiàn)"按照指定的替代關系將數(shù)組str中的所有字符進行替代,替代后仍存入數(shù)組str的對應位置上"。因此本題的關鍵在于用什么樣的C程序語言實現(xiàn)指定的替代關系,之后就可以通過ー個雙重循環(huán)來將這篇文章中的所有字符逐個替換?!窘忸}思路】首先通過for循環(huán)對數(shù)組str[i]中的每ー個英文字符按照題目給定的替代算法*pf*ll%256計算出其對應的字符的ASCI!值,然后把這個ASCII值與130和32進行比較,如果這個值小于等于130且大于32,則用這個ASCI!值代替代原值。【答案】voidencryptChar(){inti;char*pf;for(i=0;i<maxline;i++){pf=str[i];while(*pf!=0)if(*pf*ll%256<=130&&*pf*ll%256>32)*pf=*pf*ll%256;pf++;))}容錯分析:題目中的條件是:如果計算后f(p)值小于等于32或大于130,則該字符不變。在程序中這個條件寫成:*pf*ll%256<=130&&*pf*ll%256>32o5.函數(shù)RData()實現(xiàn)從文件IN.dat中讀取一篇英文文章存入到字符串數(shù)組str中,請編寫函數(shù)DescSortO,其功能是:以行為單位對字符按從大到小的順序進行排序,排序后的結(jié)果仍按行重新存入字符串數(shù)組str中,最后調(diào)用函數(shù)WData。,把結(jié)果str輸出到文件OUT.dat中。原始數(shù)據(jù)文件存放的格式是:每行的寬度均小于80個字符(含標點符號和空格)。例如,原文:dAeBfC.CcbbAA結(jié)果:fedCBA.cbbCAA注意:部分程序已給出。請勿改動主函數(shù)main()、讀數(shù)據(jù)函數(shù)RData()和輸出數(shù)據(jù)函數(shù)WData()的內(nèi)容。#include<stdio.h>#include<string.h>#include<conio.h>charstr[50][80];intmaxline=0;/*文章的總行數(shù)?/intRData(void);voidWData(void);voidDescSort(void)voidmain(){if(RData()){ prindT數(shù)據(jù)文件IN.dat不能打開!\n\007”);return;)DescSort();WData();)intRData(void){FILE*fp;inti=0;char*p;if((fp=fopen("IN.daビ,"r"))==NULL)return1;while(fgets(str[i],80,fp)!=NULL){p=strchr(str[i],*\n');if(p)*p=0;i++;)maxline=i;fclose(fp);voidWData(void){FILE*fp;inti;fp=fopen("〇UT.da口W);for(i=0;i<maxline;i++){printf(,,%s\n'\str[i]);fprintf(fp,n%s\nn,str[i]);)fclose(fp);)【題目分析】分析題目可知,題中需要解決的問題就是實現(xiàn)DescSort函數(shù)的功能問題,而DescSort函數(shù)的功能是:實現(xiàn)”以行為單位對字符按從大到小的順序進行排序,排序后的結(jié)果仍按行重新存入字符串數(shù)組str中"。因此本題的關鍵在于如何判斷將字符串拆分成單獨的字母,之后就可以通過一個三重循環(huán)來將所有字符逐個比較字母的大小,并存入數(shù)組str中?!窘忸}思路】首先利用三重循環(huán)中的第一層循環(huán)將字符讀入數(shù)組strl中,然后利用內(nèi)層的二重循環(huán)對文章中每一行的字符進行兩兩比較,較小的字符往行后放,較大的字符往行前放,這樣就實現(xiàn)了以行為單位對字符從大到小的排序。在程序中的語句是if(str[i][j]<str[i][k])成立,str[i][j]和str[i][k]就交換數(shù)據(jù)?!敬鸢浮縱oidDescSort(void){inti,j,k,strl;charch;for(i=0;i<maxline;i++){strl=strlen(str[i]);for(j=0;j<strl-1;j++)for(k=j+l;k<strl;k++)if(str[i][j]<str[i][k]){ch=str[i][j];str[i][j]=str[i][k];str[i][k]=ch;容錯分析:變量j的取值范圍是〇到Strl-l,而變量k的取值范圍是j+1到strl。6函數(shù)RData()實現(xiàn)從文件IN.dat中讀取?篇英文文章存入字符串數(shù)組original中,請編寫SlrCharMove。函數(shù),其功能是:以行為單位把字符串中所有字符的ASCII值右移4位,然后把右移后的字符ASCII值再加上原字符的ASCII值,得到新的字符仍存入原字符串對應的位置上。最后把己處理的字符串仍按行車新存入字符串數(shù)組original中。最后調(diào)用函數(shù)WData(),把結(jié)果original輸出到文件OUT.dat中。原始數(shù)據(jù)文件存放的格式是:每行的寬度均小于80個字符(含標點符號和空格)。注意:部分程序已給出。請勿改動主函數(shù)main。、讀數(shù)據(jù)函數(shù)RData()和輸出數(shù)據(jù)函數(shù)WData。的內(nèi)容。#include<stdio.h>#include<string.h>#include<conio.h>charoriginal[50][80];intmaxline=0;/?文章的總行數(shù)?/iniRData(void);voidWData(void);voidStrCharMove(void)voidmain(){if(RData()){ printf("數(shù)據(jù)文件IN.dat不能打開!'n\007");return;)StrCharMove();WData();)iniRData(void)(FILE*fp;inti=0;char*p;if((fp=fopen(HIN.daf\==NULL)return1;while(fgets(original[i],80,fp)!=NULL){p=strchr(original[i『\n');if(P)*p=0;i++;)maxline=i;fclose(fp);return0;}voidWData(void){FILE*fp;fp=fopen(HOUT.datM,MwH);for(i=0;i<maxline;i++){printf(M%s\nH,original[i]);fprintf(fp,n%s\nn,originai[i]);)fclose(fp);}【知識點播】ASCH碼值的右移運算可以通過運算符(?)來實現(xiàn),左移運算符為(?),【題目分析】分析題目可知,題中需要解決的問題是實現(xiàn)StrCharMove函數(shù)的功能問題,而StrCharMove函數(shù)的功能是:以行為單位把字符串中所有字符的ASCH值右移4位,然后把右移后的字符ASCII值再加上原字符的ASCII值,得到新的字符仍存入原字符串對應的位置上,最后把已處理的字符串仍按行重新存入字符串數(shù)組original中。因此本題的關鍵在于如何進行ASCII值的右移運算。【解題思路】首先用字符串函數(shù)strlen求出每行的長度,然后在for循環(huán)語句中將每個字符轉(zhuǎn)換成ASCII碼值;接著右移4位,即originaゆ皿>>4:再和original[i][j]的值相加:最后將得到的ASCII碼值轉(zhuǎn)換成字符并存入數(shù)組original中?!敬鸢浮縱oidStrCharMove(void){inti,j,strl;for(i=0;i<maxline;i++){strl=strlen(original[i]);for(j=0;j<strl;j++)original[i]|j]+=original[i]|j]?4;容錯分析:字符的ASCII碼值右移4位,再和原值相加,用語句original[i][j]+=original[i](j]?4實現(xiàn)。7.編寫函數(shù)findStr。,其功能是:統(tǒng)計ー個長度為2的子字符串在另ー個字符串中出現(xiàn)的次數(shù)。例如,假定輸入的字符串為”asdasasdfgasdaszx67asdmklo”,子字符串為“as”,函數(shù)返回值是6〇函數(shù)ReadWrite()實現(xiàn)從文件IN.dat中讀取兩個字符串,并調(diào)用函數(shù)flndStr。,最后,把結(jié)果輸出到文件OUT.dat中。注意:部分程序已經(jīng)給出。請勿改動主函數(shù)main。和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)findSlrQ的花括號中填入編寫的若干語句。#include<stdio.h>#include<string.h>#include<conio.h>intfindStr(char*str,char*substr)voidReadWrite(){charstr[81],substrflO],ch;intn,len,i=0;FILE*rf,*wf;rf=fopen(MIN.dat,\V);wf=fopen("〇UT.daJ”w");while(i<25){fgets(str,81,rf);fgets(substr,10,rf);len=strlen(substr)-1;ch=substr[len];if(ch==,\n,IIch=0xla)substr[len]=0;n=findStr(str,substr);fprintf(wf,"%d\n",n);i++;}fclose(rf);fclose(wf);1main(){charstr[81],substr[10];intn;printf("輸入原字符串:");gets(str);printf("輸入子字符串:");gets(substr);puts(str);puts(substr);n=findStr(str,substr);printf(,,n=%d\n';n);ReadWrite();}【題目分析】分析題目可知,題中需要解決的問題就是實現(xiàn)findStr函數(shù)的功能問題,而findStr函數(shù)的功能是:統(tǒng)計滿足"ー個長度為2的子字符串在另ー個字符串”條件的字符串出現(xiàn)的次數(shù)。因此本題的關鍵在于如何判斷ー個字符串在另外一個字符串中?!窘忸}思路】這里用字符指針p和r分別指向字符串和子字符串,在while循環(huán)中比較電和*p的值,如果兩者的值相等,則r和p分別加1:如果兩者不相等,則對?r的值進行判斷。如果*r的值等于VX,則說明在字符串?str中找到了一個與?substr相匹配的字符串,所以n加1。然后str加1,進入下ー個尋找與子字符相匹配循環(huán),直到退出while(*str)循環(huán),返回的整數(shù)n值就是與子字符串相匹配字符串的個數(shù)。【答案】intfindStr(char*str,char*substr){intn;char*p,*r;n=0;while(*str){p=str;r=substr;while(*r)if(*r==*p){ r++;P++;}else{break;)if(*r=='\0')n++;str++;1returnn;容錯分析:字符串的最后一個字符是null,所以當字符串指針str和r達到字符串的結(jié)尾時,就自動退出while循環(huán)。8.請編寫函數(shù)CounlValueO,它的功能是:求n以內(nèi)(不包括n),同時能被3與7整除的所有自然數(shù)之和的平方根s,并作為函數(shù)值返回。主函數(shù)最后調(diào)用函數(shù)progReadWri眞)從IN.dat文件中讀取10組數(shù)據(jù),分別得出結(jié)果,且把結(jié)果輸出到文件OUT.dat中。例如,若n為1000時,函數(shù)值應為:s=153,909064o注意:部分程序已經(jīng)給出。請勿改動主函數(shù)main。和輸入輸出數(shù)據(jù)函數(shù)progReadWrite。的內(nèi)容。#include<conio.h>#include<math.h>#include<stdio.h>doubleCountValue(intn)voidprogReadWrite(){FILE*fp,*wf;inti,n;floats;fp=fopen(,'in.datM,urH);if(fp==NULL){ primf("數(shù)據(jù)文件in.dat不存在!”);return;)wf=fopen("out.dat“,"w");for(i=0;i<10;i++){fscanf(fp,M%d,",&n);s=(float)countValue(n);fprintf(wf,n%AnH,s);)fclose(fp);fclose(wf);)main(){printf(M1000以內(nèi)符合條件的自然數(shù)之和的平方根=%f\n”,CountValue(lOOO));progReadWrite();)【題目分析】分析題目可知,CountValue()函數(shù)要實現(xiàn)3個功能:①求出n以內(nèi)所有能被3和7整除的整數(shù);②將這些整數(shù)相加求它們的和;③對這個和求平方根?!窘忸}思路】這里我們先通過for循環(huán)語句來求出n以內(nèi)所有能被3和7整除的整數(shù)同時對這些數(shù)求和;然后把和轉(zhuǎn)化為雙精度型數(shù)據(jù),利用開平方函數(shù)sqrt()求出這個和數(shù)的平方根。【答案】doublecountValue(intn){doublexy=0.0;inti;fbr(i=l;i<n;i++)if(i%3==0&&i%7==0)xy+=i;xy=sqrt((double)xy);returnxy;)容錯分析:能被3和7整除的整數(shù)的條件為:i%3==0&&i%7==0;在求和的平方根之前,首先要把和數(shù)的類型轉(zhuǎn)化為雙精度型。9已知在文件IN.dat中存有N個(N<200)實數(shù),函數(shù)RData()讀取這N個實數(shù)并存入數(shù)組original中。請編寫函數(shù)CalValue(),要求實現(xiàn)的功能有:①求出這N個實數(shù)的平均值(aver);②分別求出這N個實數(shù)的整數(shù)部分之和(sumint)以及小數(shù)部分之和(sumdec),最后調(diào)用函數(shù)WData()把所求的結(jié)果輸出到文件OUT.dat中。注意:部分源程序已給出。請勿改動主函數(shù)main。、讀數(shù)據(jù)函數(shù)RData。和輸出數(shù)據(jù)函數(shù)WData()的內(nèi)容。#include<stdio.h>#include<conio.h>#defineMAXNUM200floatoriginal[MAXNUMJ;doubleaver=0.0;longsumint=0;doublesumdec=0.0;intRData(void);voidWData(void);voidCalValue(void)voidmain(){inti;for(i=0;i<MAXNUM;i++)original[i]=0;if(RDataO){ printf("數(shù)據(jù)文件IN.dat不能打開!'0075”);return;CalValue();printf("平均值=%.21f\n”,aver);primf("整數(shù)部分之和=%ld\n",sumint);printf("小數(shù)部分之和二%⑵f\n",sumdec);WData();1intRData(void){FILE*fp;inti=0;if((fp=fopen(”lN.dat”,”r”))==NULL)return1;while(!feof(fp))fscanf(fp,”%f,”,&original[i++]);fclose(fp);return0;}voidWData(void){FILE*fp;fp=fopen(”〇UT.dat”,”w”);fprintf(fp,”%.21f\n%ld\n%.21f\n”,aver,sumint,sumdec);fclose(fp);1【題目分析】分析題目可知,函數(shù)CalValue。函數(shù)要實現(xiàn)2個功能:①求出這N個實數(shù)的平均直(aver);②分別求出這N個實數(shù)的整數(shù)部分之和(sumint)以及小數(shù)部分之和(sumdec)?!窘忸}思路】這里我們可以利用for循環(huán)語句對數(shù)組origina川中的每ー個實數(shù)逐個進行處理。對于每ー個實數(shù)。riginaUi],在其數(shù)據(jù)前面加上(int)就得到這個實數(shù)的整數(shù)部分;用。riginal國減去(int)original[i]就得到這個實數(shù)的小數(shù)部分。然后分別求出MAXNUM個實數(shù)的和(sum)、整數(shù)部分的和(sumint)、小數(shù)部分的和(sumdec)。最后用sum除以MAXNUM就得到平均值(aver)。【答案】voidCalValue(void){inti;doublex,sum=0;for(i=0;i<MAXNUM;i++){sumint=sumint+(int)original[i];x=original[i]-(int)original[i];sumdec=sumdec+x;sum=sum+original[i];)aver=sum/MAXNUM;}容錯分析:實數(shù)分成整數(shù)部分和小數(shù)部分,在實數(shù)前面加上(int)就得到這個實數(shù)的整數(shù)部分,實數(shù)減去整數(shù)部分就得到小數(shù)部分。10.已知數(shù)據(jù)文件lN.dat中存有300個四位數(shù),并已調(diào)用讀函數(shù)Rdata()把這些數(shù)存入數(shù)組a中,請編寫函數(shù)primeNum。,其功能是:求出所有這些四位數(shù)中素數(shù)的個數(shù)count,再把所有滿足此條件的四位數(shù)依次存入數(shù)組b中,然后對數(shù)組b的四位數(shù)按從小到大的順序進行排序。最后調(diào)用寫函數(shù)Wdata(),把結(jié)果輸出到OUT.dat文件中。例如,5591是素數(shù),則該數(shù)滿足條件存入數(shù)組b中,且個數(shù)count=count+l。9812是非素數(shù),則該數(shù)不滿足條件,不存入數(shù)組b中,count值也不加1。注意:部分源程序已經(jīng)給出。程序中已定義數(shù)組a[300]、b[300],已定義變量count。請勿改動主函數(shù)main()、讀函數(shù)Rdata()和寫函數(shù)Wdata()的內(nèi)容。#include<stdio.h>inta[300],b[300],count=0;intisP(intm){inti;for(i=2;i<m;i++)if(m%i==0)return0;return1;)voidprimeNum()voidRdata(){FILE*fp;inti;fp=fopen(”in.daビ,"r");for(i=0;i<300;i++)fscanf(fp,&a[i]);fclose(fp);)voidWdata(){FILE*fp;inti;fp=fopen("〇ut.da「W);fprintf(fp,"%d\n",count);for(i=0;i<count;i++)fprintf(fp,"%d\n”,b[i]);fclose(fp);main(){inti;Rdata();primeNumO;Wdata();printf("count=%d\n",count);for(i=0;i<count;i++)printf("b[%d]=%d\n",i,b[i]);)【題目分析】分析題目可知,本題只要實現(xiàn)primeNum。函數(shù)的功能即可。primeNum。要實現(xiàn)的功能是:求出所有這些四位數(shù)是素數(shù)的個數(shù)count,再把所有滿足此條件的四位數(shù)依次存入數(shù)組b中,然后對數(shù)組b的四位數(shù)按從小到大的順序進行排序。因此解答本題的關鍵在于如何判斷ー個四位數(shù)為素數(shù)?!窘忸}思路】用for循環(huán)對300個整數(shù)調(diào)用子函數(shù)isP(a[i])進行判斷其是否是素數(shù),如果是素數(shù),則把a國賦給數(shù)組b,同時計數(shù)變量count加1。最后利用雙重循環(huán)對數(shù)組b中的元素進行從小到大的排序?!敬鸢浮縱oidprimeNum(){intj,i,value;for(i=0;i<300;i++)if(isP(a[i])){b[countj=a[i];count++;)for(i=0;i<count-l;i++)for(j=i+1;j<count;j++)if(b[i]>bU]){value=b[i];b[i]=bU];b[j]=value;容錯分析:在兩層for循環(huán)中,內(nèi)層循環(huán)是從i+1開始H到count。11.下列程序的功能是:把s字符串中的所有字符左移ー個位置,字符串中的第一個字符移到最后。請編寫函數(shù)change(char*s)實現(xiàn)程序要求,最后調(diào)用函數(shù)readwriteDAT()從IN.dat文件中讀取50組數(shù)據(jù),分別得出結(jié)果,且把結(jié)果輸出到OUT.dat文件中。例如,s字符串中原有內(nèi)容為:Mn.l23xyZ,調(diào)用該函數(shù)后結(jié)果為:n」23xyZM。注意:部分源程序已經(jīng)給出。請勿改動主函數(shù)main()和輸出數(shù)據(jù)函數(shù)readwriteDAT。中的內(nèi)容。#include<string.h>#include<stdio.h>#defineN81voidreadwriteDAT();voidchange(char*s)main(){chara[NJ;printf("Enterastringゴ’);gets(a);printf(nTheoriginalstringis:");puts(a);change(a);printf(MThestringaftermodified:");puts(a);readwriteDAT();)voidreadwriteDAT(){inti;chara[N];FILE*rf,*wf;rf=fopen(nIN.datn,V);wf=fopen("〇UT.dat",”w");for(i=0;i<50;i++){fscanf(rf,"%s",a);change(a);fprintf(wf,M%s\nM,a);}fclose(rf);fclose(wf);1【題目分析】分析題目可知,本題只要實現(xiàn)change(char*s)函數(shù)的功能即可。change(char*s)要實現(xiàn)的功能是:把s字符串中的所有字符左移ー個位置,串中的第一個字符移到最后。因此解答本題的關鍵在于如何將字符串拆分成單個字符并賦值給數(shù)組,并通過數(shù)組的下標將字符逐個左移一位?!窘忸}思路】首先用字符串函數(shù)strlen求出字符串s的長度,賦給變量strl;再把字符串的首字符賦給字符變量ch;然后在for循環(huán)語句中,變量i從。遞增到strLl,字符串s中的所有字符左移ー個位置;最后把字符變量ch的值賦給?(s+strl?l),即完成了題目要求的功能。【答案】voidchange(char*s){inti,strl;charch;strl=strlen(s);ch=*s;for(i=0;i<strl-1;i++)*(s+i)=*(s+i+l);*(s+strl-l)=ch;}容錯分析:在字符串左移時要首先把首字符存入一個字符變量中。12.下列程序的功能是:找出所有100以內(nèi)(含100)滿足1、1+4、1+1()都是素數(shù)的整數(shù)1(1+1()也在100以內(nèi))的個數(shù)count以及這些i之和sum。請編寫函數(shù)primeNum。實現(xiàn)程序要求的功能,最后調(diào)用函數(shù)writeDat。,把結(jié)果count和sum輸出到文件OUT.dal中。注意:部分源程序已經(jīng)給出。請勿改動主函數(shù)main()和輸出數(shù)據(jù)函數(shù)writeDat。的內(nèi)容。#include<stdio.h>intcount,sum;intisPrime(intnumber){inti,tag=1;for(i=2;tag&&i<=number/2;i++)if(number%i==0)tag=0;returntag;voidprimeNum()voidwriteDat(){FILE*fp;fp=fopen("〇UT.daピ,"w“);fprintf(fp,n%d\n%d\nn,count,sum);fclose(fp);)voidmain(){count=sum=0;primeNum();printf("滿足條件的整數(shù)的個數(shù)=%d\n",count);printf("滿足條件的整數(shù)的和值=%d\n”,sum);writeDat();)【題目分析】分析題目可知,本題只要實現(xiàn)primeNum。函數(shù)的功能即可。primeNum。要實現(xiàn)的功能是:找出所有100以內(nèi)(含100)滿足i、i+4、i+10都是素數(shù)的整數(shù)i(i+10也在100以內(nèi))的個數(shù)count以及這些i之和sum。因此解答本題的關鍵在于如何將"i、i+4、i+10都是素數(shù)”條件轉(zhuǎn)換成C語言表達式?!窘忸}思路】在for循環(huán)語句中自

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論