



下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
计算机三级数据库上机题库1.调用函数rwdata(),从IN.dat文件中读取10组数据(m和k值),并嵌套调用primenum函数分别得出array口数组。请编写函数primenum(intm,intk,intarray[]),该函数的功能是:将紧靠m的k个素数存入数组array并在屏幕上显示。最后把结果输出到文件OUT.dat中。例如,若输入39,则应输出5711131719232931。注意:部分程序已经给出。请勿改动主函数main。利输出数据函数rwdata()的内容。#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);【知识点播】素数的定义:如果ー个数的正因子只有1和这个数本身,那么这个数就是素数。【题目分析】分析题目可知,题中需要解决的问题就是Primenum函数的功能问题(rwdata函数功能题中已经给出),而Primenum函数的功能是求在指定数m之后的k个素数,因此本题的关键在于如何判断ー个数是素数,之后就可以通过ー个for循环来求得在m之后的k个素数了。【解题思路】根据素数的定义,本题采用的算法是:首先定义ー个变量Value,并把m之后的数逐个赋值给该变量;然后用2-value/2数除value»如果value能被2〜value/2之中的任何ー个整数整除,则value不是素数,结束循环;如果value不能被2〜value/2之间的任一•整数整除,则退出循环,然后判断循环变量i是否大于value/2,如果大于,则value是素数,并将value值赋给array[川,然后n++;再判断n是否大于等于k,如果大于等于k,就完成了程序要求的功能,退出循环,否则value加1,根据以上算法继续进行。【答案】voidprimenum(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++;)}【容错分析】判断ー个数m(大于1)是否素数的简单的算法:枚举2到m/2之间的整数,看能否被m整除,如果能整除,就不是素数,否则是素数。2.在文件IN.dat中有200个正整数,且每个数均在!000-9999之间。函数RData()读取这200个数存放到数组original中。请编写函数numAscend。,其功能是:要求按每个数的后3位的大小进行升序排列,然后取出满足此条件的前10个数依次存入数组result中,如果后3位的数值相等,则按原先的数值进行降序排列。最后调用函数WData(),把结果result输出到文件OUT.dat中。例如,处理前:60125099901270258088处理后:90126012702580885099注意:部分程序已给出。请勿改动主函数main。、读数据函数RData()和输出数据函数WData()的内容。#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数组中各元素数字的后3位数的大小进行升序排列,如果数值相等,则按原先的数值进行降序排列;②取出排序后的original数组中的前10个数依次存入result数组中。【解题思路】根据上面的分析,编写程序有以下几个步骤:第1步:首先分解出数组中两个元素的后三位,这里采用在两次循环中求出正整数original[i]和original[j]Xt1000的余数的方法;第2步:然后比较两个数余数的大小,如果正整数original[i]和originalfj]对1000的余数不相同,则按照升序进行排序,如果相同,则比较original[i]和original5的大小,按照降序进行排序;第3步:利用ー个for循环语句把original数组中的前10个数输出给result数组。【答案】voidnumascend(){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];
容错分析:数组original[i]中两个数的位置交换要借助中间变量data。3.已知文件IN.dat中存有100个产品销售记录,毎个产品销售记录由产品代码code(字符型4位)、产品名称name(字符型10位)、騷uprice(整型)、数量amount(整型)、金额sum(长整型)5部分组成。其中:金额=单价X数量。函数RData()读取这100个销售记录并存入结构数组sell中。请编写函数DescSort(),其功能要求:按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WData(),把结果输出到文件OUT.dat中。注意:部分程序已给出。请勿改动キ:函数main。、读数据函数RData()和输出数据函数WData()的内容。#include<stdio.h>#include<string.h>#include<conio.h>#include<stdlib.h>#defineMAX100typedefstructcharcode[5];/charcode[5];/・产品代码・/charname[l1];charname[l1];/・产品名称・/intuprice;/intuprice;/・单价*/intamount;/intamount;/・数量・/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);}【题目分析】首先我们来看看题中要求我们解决的问题有哪些。①按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列;②将排列结果存入结构数组sell中。分析题目可知,本题中使用结构数组sell来保存销售记录。产品代码存储在sell结构数组中的code成员中,金额存储在sum成员中。【解题思路】我们可以利用两个for循环结构对产品销售记录(strcmp(se叩].code,seUm.code))两两进行循环比较,如果这个表达式返回结果值小于〇,则进行两个数据的交换,实现产品代码从大到小进行排序。如果上面的表达式的返回值等于0,说明这两个产品的代码相同,则比较sell[i].sum与比l[j].sum的值。如果sell[i].sumvsell|j].sum,则进行两个数据的交换,实现金额从大到小进行排序。【答案】voidDescSort(){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;}}}容错分析:数组sell[i]中两个数的位置交换要借助中间变量tempo4.函数RData()实现从文件IN.dat中读取ー篇英文文章,存入到字符串数组str中;请编写encryptChar()函数,其功能是:按给定的替代关系对数组str中的所有字符进行替代,仍存入数组str对应的位置上,最后调用函数WData(),把结果str输出到文件OUT.dat中。替代关系:f(p)=p*llmod256(p是数组中某ー个字符的ASCII值,f(p)是计算后新字符的ASCI!值),如果计算后f(p)值小于1等于32或大于130,则该字符不变,否则将f(p)所对应的字符进行替代。原始数据文件存放的格式是:每行的宽度均小于80个字符。注意:部分程序已给出。请勿改动主函数main。、读数据函数RData()和输出数据函数WData()的内容。#include<stdio.h>#include<string.h>#include<conio.h>#include<clype.h>unsignedcharstr[50][80];intmaxline=0;/・文章的总行数・/intRData(void);voidWData(void);voidencryptChar()voidmain(){if(RData()){ printf("数据文件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);)【题目分析】分析题目可知,题中需要解决的问题就是实现encryptChar函数的功能问题,而encryptChar函数的功能是:实现"按照指定的替代关系将数组str中的所有字符进行替代,替代后仍存入数组str的对应位置上"。因此本题的关键在于用什么样的C程序语言实现指定的替代关系,之后就可以通过ー个双重循环来将这篇文章中的所有字符逐个替换。【解题思路】首先通过for循环对数组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.函数RData()实现从文件IN.dat中读取一篇英文文章存入到字符串数组str中,请编写函数DescSortO,其功能是:以行为单位对字符按从大到小的顺序进行排序,排序后的结果仍按行重新存入字符串数组str中,最后调用函数WData。,把结果str输出到文件OUT.dat中。原始数据文件存放的格式是:每行的宽度均小于80个字符(含标点符号和空格)。例如,原文:dAeBfC.CcbbAA结果:fedCBA.cbbCAA注意:部分程序已给出。请勿改动主函数main()、读数据函数RData()和输出数据函数WData()的内容。#include<stdio.h>#include<string.h>#include<conio.h>charstr[50][80];intmaxline=0;/*文章的总行数・/intRData(void);voidWData(void);voidDescSort(void)voidmain(){if(RData()){ prindT数据文件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);)【题目分析】分析题目可知,题中需要解决的问题就是实现DescSort函数的功能问题,而DescSort函数的功能是:实现”以行为单位对字符按从大到小的顺序进行排序,排序后的结果仍按行重新存入字符串数组str中"。因此本题的关键在于如何判断将字符串拆分成单独的字母,之后就可以通过一个三重循环来将所有字符逐个比较字母的大小,并存入数组str中。【解题思路】首先利用三重循环中的第一层循环将字符读入数组strl中,然后利用内层的二重循环对文章中每一行的字符进行两两比较,较小的字符往行后放,较大的字符往行前放,这样就实现了以行为单位对字符从大到小的排序。在程序中的语句是if(str[i][j]<str[i][k])成立,str[i][j]和str[i][k]就交换数据。【答案】voidDescSort(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函数RData()实现从文件IN.dat中读取・篇英文文章存入字符串数组original中,请编写SlrCharMove。函数,其功能是:以行为单位把字符串中所有字符的ASCII值右移4位,然后把右移后的字符ASCII值再加上原字符的ASCII值,得到新的字符仍存入原字符串对应的位置上。最后把己处理的字符串仍按行車新存入字符串数组original中。最后调用函数WData(),把结果original输出到文件OUT.dat中。原始数据文件存放的格式是:每行的宽度均小于80个字符(含标点符号和空格)。注意:部分程序已给出。请勿改动主函数main。、读数据函数RData()和输出数据函数WData。的内容。#include<stdio.h>#include<string.h>#include<conio.h>charoriginal[50][80];intmaxline=0;/・文章的总行数・/iniRData(void);voidWData(void);voidStrCharMove(void)voidmain(){if(RData()){ printf("数据文件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码值的右移运算可以通过运算符(»)来实现,左移运算符为(«),【题目分析】分析题目可知,题中需要解决的问题是实现StrCharMove函数的功能问题,而StrCharMove函数的功能是:以行为单位把字符串中所有字符的ASCH值右移4位,然后把右移后的字符ASCII值再加上原字符的ASCII值,得到新的字符仍存入原字符串对应的位置上,最后把已处理的字符串仍按行重新存入字符串数组original中。因此本题的关键在于如何进行ASCII值的右移运算。【解题思路】首先用字符串函数strlen求出每行的长度,然后在for循环语句中将每个字符转换成ASCII码值;接着右移4位,即originaゆ皿>>4:再和original[i][j]的值相加:最后将得到的ASCII码值转换成字符并存入数组original中。【答案】voidStrCharMove(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实现。7.编写函数findStr。,其功能是:统计ー个长度为2的子字符串在另ー个字符串中出现的次数。例如,假定输入的字符串为”asdasasdfgasdaszx67asdmklo”,子字符串为“as”,函数返回值是6〇函数ReadWrite()实现从文件IN.dat中读取两个字符串,并调用函数flndStr。,最后,把结果输出到文件OUT.dat中。注意:部分程序已经给出。请勿改动主函数main。和其他函数中的任何内容,仅在函数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();}【题目分析】分析题目可知,题中需要解决的问题就是实现findStr函数的功能问题,而findStr函数的功能是:统计满足"ー个长度为2的子字符串在另ー个字符串”条件的字符串出现的次数。因此本题的关键在于如何判断ー个字符串在另外一个字符串中。【解题思路】这里用字符指针p和r分别指向字符串和子字符串,在while循环中比较电和*p的值,如果两者的值相等,则r和p分别加1:如果两者不相等,则对・r的值进行判断。如果*r的值等于VX,则说明在字符串・str中找到了一个与・substr相匹配的字符串,所以n加1。然后str加1,进入下ー个寻找与子字符相匹配循环,直到退出while(*str)循环,返回的整数n值就是与子字符串相匹配字符串的个数。【答案】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达到字符串的结尾时,就自动退出while循环。8.请编写函数CounlValueO,它的功能是:求n以内(不包括n),同时能被3与7整除的所有自然数之和的平方根s,并作为函数值返回。主函数最后调用函数progReadWri眞)从IN.dat文件中读取10组数据,分别得出结果,且把结果输出到文件OUT.dat中。例如,若n为1000时,函数值应为:s=153,909064o注意:部分程序已经给出。请勿改动主函数main。和输入输出数据函数progReadWrite。的内容。#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("数据文件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以内符合条件的自然数之和的平方根=%f\n”,CountValue(lOOO));progReadWrite();)【题目分析】分析题目可知,CountValue()函数要实现3个功能:①求出n以内所有能被3和7整除的整数;②将这些整数相加求它们的和;③对这个和求平方根。【解题思路】这里我们先通过for循环语句来求出n以内所有能被3和7整除的整数同时对这些数求和;然后把和转化为双精度型数据,利用开平方函数sqrt()求出这个和数的平方根。【答案】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整除的整数的条件为:i%3==0&&i%7==0;在求和的平方根之前,首先要把和数的类型转化为双精度型。9已知在文件IN.dat中存有N个(N<200)实数,函数RData()读取这N个实数并存入数组original中。请编写函数CalValue(),要求实现的功能有:①求出这N个实数的平均值(aver);②分别求出这N个实数的整数部分之和(sumint)以及小数部分之和(sumdec),最后调用函数WData()把所求的结果输出到文件OUT.dat中。注意:部分源程序已给出。请勿改动主函数main。、读数据函数RData。和输出数据函数WData()的内容。#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("数据文件IN.dat不能打开!'0075”);return;CalValue();printf("平均值=%.21f\n”,aver);primf("整数部分之和=%ld\n",sumint);printf("小数部分之和二%⑵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【题目分析】分析题目可知,函数CalValue。函数要实现2个功能:①求出这N个实数的平均直(aver);②分别求出这N个实数的整数部分之和(sumint)以及小数部分之和(sumdec)。【解题思路】这里我们可以利用for循环语句对数组origina川中的每ー个实数逐个进行处理。对于每ー个实数。riginaUi],在其数据前面加上(int)就得到这个实数的整数部分;用。riginal国减去(int)original[i]就得到这个实数的小数部分。然后分别求出MAXNUM个实数的和(sum)、整数部分的和(sumint)、小数部分的和(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;}容错分析:实数分成整数部分和小数部分,在实数前面加上(int)就得到这个实数的整数部分,实数减去整数部分就得到小数部分。10.已知数据文件lN.dat中存有300个四位数,并已调用读函数Rdata()把这些数存入数组a中,请编写函数primeNum。,其功能是:求出所有这些四位数中素数的个数count,再把所有满足此条件的四位数依次存入数组b中,然后对数组b的四位数按从小到大的顺序进行排序。最后调用写函数Wdata(),把结果输出到OUT.dat文件中。例如,5591是素数,则该数满足条件存入数组b中,且个数count=count+l。9812是非素数,则该数不满足条件,不存入数组b中,count值也不加1。注意:部分源程序已经给出。程序中已定义数组a[300]、b[300],已定义变量count。请勿改动主函数main()、读函数Rdata()和写函数Wdata()的内容。#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]);)【题目分析】分析题目可知,本题只要实现primeNum。函数的功能即可。primeNum。要实现的功能是:求出所有这些四位数是素数的个数count,再把所有满足此条件的四位数依次存入数组b中,然后对数组b的四位数按从小到大的顺序进行排序。因此解答本题的关键在于如何判断ー个四位数为素数。【解题思路】用for循环对300个整数调用子函数isP(a[i])进行判断其是否是素数,如果是素数,则把a国赋给数组b,同时计数变量count加1。最后利用双重循环对数组b中的元素进行从小到大的排序。【答案】voidprimeNum(){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循环中,内层循环是从i+1开始H到count。11.下列程序的功能是:把s字符串中的所有字符左移ー个位置,字符串中的第一个字符移到最后。请编写函数change(char*s)实现程序要求,最后调用函数readwriteDAT()从IN.dat文件中读取50组数据,分别得出结果,且把结果输出到OUT.dat文件中。例如,s字符串中原有内容为:Mn.l23xyZ,调用该函数后结果为:n」23xyZM。注意:部分源程序已经给出。请勿改动主函数main()和输出数据函数readwriteDAT。中的内容。#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【题目分析】分析题目可知,本题只要实现change(char*s)函数的功能即可。change(char*s)要实现的功能是:把s字符串中的所有字符左移ー个位置,串中的第一个字符移到最后。因此解答本题的关键在于如何将字符串拆分成单个字符并赋值给数组,并通过数组的下标将字符逐个左移一位。【解题思路】首先用字符串函数strlen求出字符串s的长度,赋给变量strl;再把字符串的首字符赋给字符变量ch;然后在for循环语句中,变量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以内(含100)满足1、1+4、1+1()都是素数的整数1(1+1()也在100以内)的个数count以及这些i之和sum。请编写函数primeNum。实现程序要求的功能,最后调用函数writeDat。,把结果count和sum输出到文件OUT.dal中。注意:部分源程序已经给出。请勿改动主函数main()和输出数据函数writeDat。的内容。#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("满足条件的整数的个数=%d\n",count);printf("满足条件的整数的和值=%d\n”,sum);writeDat();)【题目分析】分析题目可知,本题只要实现primeNum。函数的功能即可。primeNum。要实现的功能是:找出所有100以内(含100)满足i、i+4、i+10都是素数的整数i(i+10也在100以内)的个数count以及这些i之和sum。因此解答本题的关键在于如何将"i、i+4、i+10都是素数”条件转换成C语言表达式。【解题思路】在for循环语句中自
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 小学折叠经典题目及答案
- 电气培训 课件
- 推广培训课件
- 2024年河北公务员行测真题(C类)
- 2024年黔东南州榕江县事业单位专项招聘考试真题
- 微体化石纳米结构分析-洞察及研究
- 肿瘤微环境调控-第5篇-洞察及研究
- 河南天一大联考高中毕业班阶段性测试(二)数学(文科)试题附答案
- 肿瘤干细胞靶向治疗-洞察及研究
- 山东省聊城东阿县联考2025届英语七年级第二学期期中学业水平测试模拟试题含答案
- 数据库程序设计智慧树知到期末考试答案章节答案2024年外交学院
- 中职数学单招一轮总复习《集合》复习课件
- 外来医疗器械清洗消毒
- 内科学(广东药科大学)智慧树知到期末考试答案2024年
- 再回首混声合唱谱
- 2023年11月南昌高新技术产业开发区人民检察院招考4名聘用制检察辅助人员笔试近6年高频考题难、易错点荟萃答案带详解附后
- 珍爱生命远离溺水风险
- 运输行业保密知识培训
- 23秋国家开放大学《视觉设计基础》形考任务1-5参考答案
- 南平市浦城县石陂镇社区工作者招聘考试基础题汇总2023
- 《汽车发动机构造与维修》(配实训工单) 教案 5-1冷却系结构与循环线路(4学时)
评论
0/150
提交评论