2023年三级网络技术上机试题南开100题

☆题目1请编写一个函数jsValue(int m,int k,int xx[]),该函数的功能是:将大于整数m且紧靠m的k个素数存入数组xx传回 最后调用函数writeDat()读取10组数据,分别得出结果且把结果输出到文献out.dat中 部分源程序存在文献prog1.c中 例如:若输入17 5 则应输出:19,23,29,31,37 请勿改动主函数main()和写函数writeDat()的内容int isP(int m){ int i; for(i=2;i
最后main( )函数调用写函数writeDat()把结果cnt以及数组b中符合条件的四位数输出到OUT.DAT文献中 void jsVal(){ int i,j,qw,bw,sw,gw; for(i=0;i 最后main()函数调用函数WriteDat()把结果xx输出到文献OUT5.DAT中void StrOR(void){int i,righto,j,s,k; char tem[80]; for(i=0;i 最后把已解决的字符串(应不含标点符号)仍按行重新存入字符串数组xx中,最后调用函数writeDat()把结果xx输出到文献OUT6.DAT中 例如:原文:You He Me I am a student. 结果:Me He You student a am I void StrOL(void) { int i,j,k,s,m,strl; char str[80]; for(i=0;i 函数ReadDat()读取这200个数存放到数组aa中请编制函数jsSort(),其函数的功能是:规定按每个数的后三位的大小进行升序排列,然后取出满足此条件的前10个数依次存入数组bb中,假如后三位的数值相等,则按原先的数值进行降序排列最后调用函数WriteDat()把结果bb输出到文献out.dat中 例:解决前 6012 5099 9012 7025 8088 解决后 9012 6012 7025 8088 5099 void jsSort(){ int i,j,data; for(i=0;i<199;i++) for(j=i+1;j<200;j++) if(aa[i]%1000>aa[j]%1000||aa[i]%1000==aa[j]%1000&&aa[i] 请编制函数jsSort(),其函数的功能是:规定按每个数的后三位的大小进行降序排列,然后取出满足此条件的前10个数依次存入数组b中,假如后三位的数值相等,则按原先的数值进行升序排列最后调用函数WriteDat()把结果bb输出到文献out.dat中例:解决前 9012 5099 6012 7025 8088 解决后 5099 8088 7025 6012 9012 void jsSort(){ int i,j,data; for(i=0;i<199;i++) for(j=i+1;j<200;j++) if(aa[i]%1000 其中:金额=单价*数量计算得出函数ReadDat()是读取这100个销售记录并存入结构数组sell中请编制函数SortDat(),其功能规定:按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文献OUT6.DAT中 void SortDat(){int i,j; PRO xy; for(i=0;i<99;i++) for(j=i+1;j<100;j++) if(strcmp(sell[i].dm,sell[j].dm)<0||strcmp(sell[i].dm,sell[j].dm)==0&&sell[i].je 替代关系:f(p)=p*11 mod 256(p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),假如计算后f(p)值小于等于32或大于130,则该字符不变,否则将f(p)所相应的字符进行替代注意中间变量用无符号整型),部分源程序存在文献prog1.c中原始数据文献存放的格式是:每行的宽度均小于80个字符 void encryptChar(){ int i,j; for(i=0;i 例:原文:dAe,BfC. CCbbAA 结果:fedCBA. bbCCAA void SortCharD(void){int i,j,k,strl; char ch; for(i=0;i 例:原文:Adb.Bcdza abck.LLhj 结果:Aec.Bdeab bcdl.LLik void ConvertCharA(void){ int i,j; for(i=0;i 其中:金额=单价*数量计算得出函数ReadDat()是读取这100个销售记录并存入结构数组sell中请编制函数SortDat(),其功能规定:按产品名称从小到大进行排列,若产品名称相等,则按金额从小到大进行排列,最终排列结果仍存入结构数组sell中, void SortDat(){int i,j; PRO xy; for(i=0;i<99;i++) for(j=i+1;j<100;j++) if(strcmp(sell[i].mc,sell[j].mc)>0||strcmp(sell[i].mc,sell[j].mc)==0&&sell[i].je>sell[j].je) {xy=sell[i];sell[i]=sell[j];sell[j]=xy;}}题目13(结构体运算题)已知在文献IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)五部分组成其中:金额=单价*数量计算得出函数ReadDat()是读取这100个销售记录并存入结构数组sell中请编制函数SortDat(),其功能规定:按产品代码从小到大进行排列,若产品代码相等,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文献OUT9.DAT中。 void SortDat(){int i,j; PRO xy; for(i=0;i<99;i++) for(j=i+1;j<100;j++) if(strcmp(sell[i].dm,sell[j].dm)>0||strcmp(sell[i].dm,sell[j].dm)==0&&sell[i].je void jsVal(){int i,j; int qw,bw,sw,gw; for (i=0;i void StrCharJR(){int i,j; for(i=0;i 替代关系:f(p)=p*11 mod 256(p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),假如原字符的ASCII值是偶数或计算后f(p)值小于等于32,则该字符不变,否则将f(p)所相应的字符进行替代 void encryptChar(){ int i,j; for(i=0;i int findStr(char *str,char *substr){ int i,j,len1,len2,cnt=0,flag; len1=strlen(str); len2=strlen(substr); for(i=0;i Xn+1=cos(Xn) 迭代环节如下:(1)取X1初值为0.0;(2)X0=X1,把X1的值赋给X0;(3)X1=cos(X0),求出一个新的X1;(4)若X0-X1的绝对值小于0.000001,执行环节(5),否则执行环节(2);(5)所求X1就是方程cos(X)-X=0的一个实根,作为函数值返回 请编写函数countValue()实现程序的规定,最后调用函数writeDat()把结果输出到文献OUT17.DAT中 float countValue(){ float x0,x1; x1=0.0; do{ x0=x1; x1=cos(x0); }while(fabs(x0-x1)>=0.000001); return x1;}注:本题在无忧或捷成模拟盘中,需定义double x0,x1;才干通过,据事实上机抽到该题的考生反映,事实上机需按上面解法的定义方能通过,特此说明,供参考★题目22(平方根问题)请编写函数countValue(),它的功能是:求n以内(不涉及n)同时能被3与7整除的所有自然数之和的平方根s,并作为函数值返回,最后结果s输出到文献out.dat中。 例如若n为1000时,函数值应为:s=153.909064double countValue(int n){ int i; double s=0.0; for(i=1;i 请编制函数实现此功能,满足该条件的整数的个数通过所编制的函数返回 int jsValue(int bb[]){int i,j,k=0; int hun,ten,data; for(i=10;i<32;i++) {j=I*I;hum=j/100;ten=j%100/10;data=j%10;if(hum==ten||hum==data||ten==data)bb[k++]=j;}return k;}★题目25 (回文数问题)下列程序的功能是:寻找并输出11至999之间的数m,它满足m,m2和m3均为回文数所谓回文数是指其各位数字左右对称的整数,例如121,676,94249等满足上述条件的数如m=11,m2=121,m3=1331皆为回文数请编制函数int svalue(long m)实现此功能,假如是回文数,则函数返回1,反之则返回0最后把结果输出到文献out.dat中int jsValue(long n){int i,strl,half; char xy[20]; ltoa(n,xy,10); /*注意这里不能使用itoa()函数,由于n是long 型的*/ strl=strlen(xy); half=strl/2; for(i=0;i 请编制函数CalValue(),其功能规定:1、求出这文献中共有多少个正整数totNum;2、求这些数右移1位后,产生的新数是偶数的数的个数totCnt,以及满足此条件的这些数(右移前的值)的算术平均值totPjz,最后调用函数writeDat()把所求的结果输出到文献OUT.DAT中 void CalValue(void){int i,data;for(i=0;i 例如:9123,9-1-2-3>0,则该数满足条件存入数组b中,且个数cnt=cnt+1 9812,9-8-1-2>0,则该数不满足条件忽略 jsValue(){ int i,j,qw,bw,sw,gw; for(i=0;i<300;i++) { qw=a[i]/1000; bw=a[i]/100%10; sw=a[i]%100/10; gw=a[i]%10; if(qw-bw-sw-gw>0) b[cnt++]=a[i]; } for(i=0;i 最后main()函数调用写函数writeDat( )把结果cnt以及数组b中符合条件的四位数输出到OUT.DAT文献中 void jsVal(){int i,j,thou,hun,ten,data,ab,cd; for(i=0;i<200;i++) {thou=a[i]/1000; hun=a[i]%1000/100; ten=a[i]%100/10; data=a[i]%10; ab=10*thou+ten; cd=10*data+hun; if((ab-cd)>=0&&(ab-cd)<=10&&ab%2==1&&cd%2==1&&ab>=10&&cd>=10) b[cnt++]=a[i]; } for(i=0;i void jsVal(){ int i,j,qw,bw,sw,gw,ab,cd; for(i=0;i void jsVal(){int i,j,flag; for(i=0;i void SortDat(){int i,j; PRO xy; for(i=0;i<99;i++) for(j=i+1;j<100;j++) if(sell[i].je 计算方差的公式如下: N 2 totfc=1/N∑(xx[i]-ave2) i=1 设N为偶数的个数,xx[i]为偶数,ave2为偶数的平均值 原始数据文献存放的格式是:每行存放10个数,并用逗号隔开每个数均大于0且小于等于2023) /*********编制函数ReadDat()的部分************/for(i=0;i 计算并输出上述这些素数的个数cnt以及这些素数值的和sum 请考生编写函数countValue( )实现程序规定,最后调用函数writeDAT()把结果cnt和sum输出到文献bc10.out中 int isPrime(int m){ int i; for(i=2;i 请勿改动主函数main()和写函数writeDat()的内容include void encryptChar(){ int i,j; for(i=0;i 其中:金额=单价*数量计算得出函数ReadDat()是读取这100个销售记录并存入结构数组sell中请编制函数SortDat(),其功能规定:按产品代码从小到大进行排列,若产品代码相同,则按金额从小到大进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文献OUT6.DAT中 void SortDat(){int i,j; PRO xy; for(i=0;i<99;i++) for(j=i+1;j<100;j++) if(strcmp(sell[i].dm,sell[j].dm)>0||strcmp(sell[i].dm,sell[j].dm)==0&&sell[i].je>sell[j].je) {xy=sell[i];sell[i]=sell[j];sell[j]=xy;}}★☆题目39(选票问题)现有一个10个人100行的选票数据文献IN.DAT,其数据存放的格式是每条记录的长度均为10位,第一位表达第一个人的选中情况,第二位表达第二个人的选中情况,依此类推 :内容均为字符0和1,1表达此人被选中,0表达此人未被选中,全选或不选均为无效的选票。 给定函数ReadDat()的功能是把选票数据读入到字符串数组xx中请编制函数CountRs()来记录每个人的选票数并把得票数依次存入yy[0]到yy[9]中把结果yy输出到文献OUT.DAT中void Coun。