内容发布更新时间 : 2024/11/5 20:25:45星期一 下面是文章的全部内容请认真阅读。
/**found**/ t=*x;*x=y; /**found**/ return(t); 3. 程序设计
请编写函数fun,函数的功能是:求出1到1000之间能被7或11整除,但不能同时被7和11整除的所有整数并将它们放在a所指的数组中,通过n返回这些数的个数。
#include
for(i=7;i<1000;i++)
if(((i%7)= =0││(i)= =0 &&(iw)!=0) a[(*n)++]=i; }
第十八套 1. 程序填空
给定程序中,函数fun的功能是:有N×N矩阵,根据给定的m(m<=n)值,将每行元素中的值均右移m个位置,左边值为0.
第1处 for(i=0;i 给定程序MODI1.C中函数fun的功能是:计算并输出high以内最大的10个素数之和。high的值由主函数传给fun函数。 /**found**/ while((2<=high)&&(n<10)) /**found**/ yes=0;break; 3. 程序设计 请编写函数fun,函数的功能是:利用一下所示的简单迭代方法求方程求方程:cos(x)-x=0的一个实根。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的一个实根作为函数值返回。程序将输出结果为:Root=0.739058。 float fun() { float x0,x1=0.0; do{ x0=x1; x1=cos(x0); }while(fabs(x0-x1)>0.000001); return x1; } 第十九套 1. 程序填空 6 给定程序中,函数fun的功能是:将a所指的3×5矩阵中第k列的元素左移到第0列,第k列以后的每列元素行依次左移,原来左边的各列依次绕到右边。 第1处for(p=1;p<=k;p++) 第2处for(j=0;j 第3处 a[i][N-1]=temp; 2. 程序修改 给定程序MODI1.C中函数fun的功能是:根据形参m的值(2<=m<=9),在m行m列的二维数组中存放如下所示规律的数据,由main函数输出。例如,若输入2则输出: 1 2 2 4 /**found**/ fun(int a[][M],int m) /**found**/ a[j][k]=(k+1)*(j+1); 3. 程序设计 函数fun的功能是:将a、b中的两位正整数合并形成一个新的整数放在c中。合并的方式是:将a中的十位和个位依次放在变量c的十位和千位上,b中的十位和个位数依次放在变量c的个位和百位上。 void fun(int a,int b,int*c) { *c=(a)*1000+(b)*100 +(a/10)*10+(b/10); } 第二十套 1. 程序填空 给定程序中,函数fun的功能是:对形参s所指字符串中下标为奇数的字符ASCII码大小递增排序,并将排序后的下标为奇数的字符取出,形成一个新串。 第1处t=i; 第2处for(j=i+2;j 给定程序MODI1.C中函数fun的功能是:用下面的公式求π的近似值,知道最后一项的近似值小于指定数(参数num)为止:例如程序0.0001,则程序输出3.1414。 /**found**/ while((fabs(t))>=num) /**found**/ t=s/n 3. 程序设计 请编写一个函数void fun(char a[ ],char b[ ],int n),其功能是:删除一个字符串指定下标的字符。其中,a指向原字符串,删除指定字符后的字符串放在b所指的n中存入指定的下标。 viod fun (char a[ ],char b[],int n) { strncpy (b,a,n); b[n]=0; strcat(b,a+n+1); } 第二十一套 1. 程序填空 给定程序中,函数fun的功能是:在形参ss所指字符串数组中,将所有串长超过k的字符串右边的字符删去,只保留左边的k个字符。ss所指字符串数组中共有N个字符串,且串小于M。 第一处 void fun(char (*ss)[M], int k) 第二处 while (i 第三处 ss[i][k]=0;i++;} 2. 程序修改 给定程序MODI1.C中函数fun的功能是:根据以下公式求π值,并作为函数值返回。例如,给指定精度的变量eps输入0.0005时,应当输出Pi=30140578.。 /**found**/ t=1; /**found**/ return(2*s); 3. 程序设计 假定输入字符串中只包含字母和*号。请编写函数fun,它的功能是:将字符串的前导*号不得多于n个;若多于n个,则删除多余的*号;若少于或等于n个,则什么也不做,字符串中间和尾部的*号不删除。函数fun中给出的语句仅供参考。 void fun(char*a,int n) { int i=0,k=0; while(a[k]= =’*’)k++; if(k>n) { i=n;j=k; for(;a[j]!=0;j++) a[i++]=a[j]; a[i]=0; }} 第二十二套 1. 程序填空 给定程序中,函数fun的功能是:a所指4×3矩阵中第k行的元素与第0行元素交换。例如:有下列矩阵 1 2 3 4 5 6 7 8 9 10 11 12 若k为2,程序执行结果为 7 8 9 4 5 6 1 2 3 10 11 12 第一处 void fun(int (*a)[N],int k) 7 第二处 for(i=0;i 给定程序MODI1.C中函数fun的功能是:读入一个字符串(长度<20),将该字符串中的所有字符串按ASCII码升序排序后输出。例如,若输入edcba,则应输出:abcde。 /**found**/ for(i=strlen(t)-1;i;i--) /**found**/ if(t[j]>t[j+1]) 3. 程序设计 请编写函数fun,函数的功能是:将ss所指字符串中所有下标为奇数位置上的字母转换为大写(若该位置上不是字母,则不转换)。 void fun(char *ss) { char *p=ss; inr i=0; while(*p){ if((i%2)&&(*p>=’a’ &&*p<=’z’)) *p-=32; p++; i++; } } 第二十三套 1. 程序填空 给定程序的功能是:调用函数fun将指定源文件中的内容复制到指定的目标文件中,复制成功时函数的返回值是1,失败是返回值是0.在复制的过程中,把复制的内容输出到终端屏幕。主函数源文件名放在变量sfname中,目标文件放在变量tfname中。 第一处 if((fs=fopen(source,”r”))==NULL) 第二处 while(!feof(fs)) 第三处 fputc(ch,ft); 2. 程序修改 给定程序MODI1.C中函数fun的功能是:将长整型中每一位上为偶数的数依次取出,构成一个新数放在t中。高位仍在高位,低位仍在低位。 /**found**/ if(d%2==0) /**found**/ s/=10; 3. 程序设计 函数fun的功能是:将两位正整数a、b合并形成一个新的整数放在c中。合并的方式是:将a中的十位和个位依次放在变量c的十位和千位上,b中的十位和个位数依次放在变量c的百位和个位上。 void fun(int a,int b,long*c) { *c=(a)*1000+(b/10)*100+(a/10)*10+(b); 第二十四套 1. 程序填空 程序通过定义学生结构体变量,存储了学生的学号、姓名和三门课的成绩。函数fun的功能是将形参a所指结构体变量中的数据赋给函数中的结构体变量b,并修改b中的学号和姓名,最后输出修改后的数据。 第一处 b=a; 第二处 strcpy(b.name,”LiSi”) 第三处 for (i=0;i<3;i++) printf(“%6.2f”,b.score[i]); 2. 程序修改 给定程序MODI1.C中函数fun的功能是:从s所指字符串中删除所有小写字母c。请改正程序中的错误,使它能计算出正确的结果。 /**found**/ s[j++]=s[i]; /**found**/ s[j]=’\\0’; 3. 程序设计 假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:将字符串的前导*号全部移到字符串的尾部。函数fun中给出的函数仅供参考。 void fun(char *a) { char *p,*q; int n=0; p=a; while(*p==’*’) {n++;p++;} q=a; while(*p){ *q=*p; p++;q++; } for(;n>0;n--) *q++=’*’; *q=’\\0’; } 第二十五套 1. 程序填空 用筛选法可得到2—n(n<10000)之间的所有 素数,方法是:首先从素数2开始,将所有2的倍数的数从数表中删去(把数表中相应位置的值置成0);接着从数表中找下一个非0数,并从数表中删去该数的所有倍数,依此类推,直到所找的下一个数等于n为止。这样会得到一个序列:2、3、5、7、11、13、17、19、23……函数fun用筛选法找出所有小于等于n的素数,并统计素数的个数作为函数值返回。 第一处 for(j=a[i]*2;j<=n;j+=a[i]) 第二处 while(a[i]= =0) 第三处 if(a[i]!=0) 2. 程序修改 给定程序MODI1.C中函数fun的功能是:为一个偶数寻找两个素数,这两个素数之和等于该偶数, 8 并将这两个素数通过形参指针传回主函数。 /**found**/ y=1; /**foune**/ d=a-i; 3. 程序设计 请编写函数fun,它的功能是:计算并输出n(包括n)以内能被5或9整除的所有自然数的倒数之和。 double fun(int n) { int i; double sum=0.0; for(i=1;i if(i%5= =0||i%9==0) sum+=1.0/i; return sum; } 第二十六套 1. 程序填空 给定程序中,函数fun的功能是建立一个N×N的矩阵。矩阵元素的构成规律是:最外层元素的值全部是1;从外向内第二层元素的值全部为2;第三层元素的值全部是3,…依此类推。 第一处void fun(int(*a)[N]) 第二处for(j=i;j 第二处a[k][i]=a[k][N-i-1]=i+1; 2. 程序修改 给定程序MODI1.C中函数fun的功能是:将十进制正整数m转换成k(2<=k <=9)进制数,并按高位到低位顺序输出。 /**found**/ aa[i]=m%k; /**found**/ printf(“%d”,aa[i-1]); 3. 程序设计 编写一个函数,从num个字符串中找出最长的一个字符串,并通过形参指针max传回该串地址。(注意:主函数中用****作为结束输入的标志,函数fun中给出的语句仅供参考)。 fun(char (*a)[81],int num,char **max) { int i,k=0,maxlen; maxlen=strlen(a[k]); for(i=1;i if(strlen(a[i])>maxlen) {maxlen=strlen(a[i]); k=i; } } *max=a[k]; } 第二十七套 1. 程序填空 函数fun的功能是计算(fx)=1+x-2/2!+3/3!-4/4!+……的前n项和。若x=2.5,n=15时,函数值为1.917914。 第一处 f=1; 第二处 t*=(-1)*x/i; 第三处 f+=t; 2. 程序修改 给定程序MODI1.C中函数fun的功能是:从三个红球,5个白球,6个黑球中任意取出8个作为一组,进行输出。在没组中,可以没有黑球,但必须要有红球和白球。组合数作为函数值返回。正确的组合数应该是15.程序中i的值代表红球数,j代表白球数,k代表黑球数。 /**found**/ for(i=1;i<=3;i++) /**found**/ if(k>=0&&k<=6) 3. 程序设计 请编写函数fun,它的功能是:计算并输出下列多项式的值:sn=1+1/1!+1/2!+1/3!+1/4!+……1/n!。例如:在主函数中从键盘给n输入15,则输出为:s=2.718282。注意:要求n的值大于1但不大于100。 double fun(int n) { double s=1’ long t=1; int i; for(i=1;i<=n;i++){ t=t*i; s+=1.0/t;} return s; } 第二十八套 1. 程序填空 给定程序中,函数fun的功能是:计算N*N矩阵的主对角线元素和方向对角线元素之和,并作为函数值返回。注意:要求先累加主对角线元素中的值,然后累加反响对角线元素的值。 第一处 sum=0; 第二处 sum+=t[i][i]; 第三处 sum+=t[i][n-i-1]; 2. 程序修改 给定程序MODI1.C中函数fun和funx的功能是:用二分法求方程2x3-4x2+3x-6=0的一个根,并要求绝对误差不超过0.001。 /**found**/ double r; /**found**/ while(fabs(n-m)>0.001) 3. 程序设计 假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:除了字符串前导和尾部的*号之 9 外,将串中其他*号全部删除。形参h已指向字符串中的第一个字母,形参p已指向字符串中最后一个字母。在编写函数时,不得使用c语言提供的字符串函数。 void fun(char *a,char *h,char *p) { int j=0; char *q=a; while(*q&&q if(*h!=’*’)a[j++]=*h; h++; } while(*p)a[j++]=*p++; a[j]=0; } 第二十九套 1. 程序填空 给定程序中,函数fun的功能是:有N*N矩阵,将矩阵的外围元素顺时针旋转。操作的顺序是:首先将第一行元素的值存入临时数组r,然后使第一列成为第一行,最后一行成为第一列,最后一列成为第一行,临时数组中和元素成为最后一列。 第一处 t[0][N-j-1]=t[j][0]; 第二处 for(j=N-1;j>=0;j--) 第三处 t[j][N-1]=r[j]; 2. 程序修改 给定程序MODI1.C中函数fun的功能是:计算s=f(-n)+f(-n+1)+……+f(0)+f(1)+f(2)+……f(n)的值。例如,当n为5时,函数值应该是:10.407143。 /**found**/ double f(double x) /**found**/ return s; 3. 程序设计 编写一个函数fun,它的功能是计算:s=根号下(ln(1)+ln(2)+ln(3)+……ln(m))S作为函数返回,在C语言中可以调用log(n)求ln(n)。log函数引用说明是:Double log(double x)例如,若m的值为:20,fun函数值为:60506583。 double fun(int m) { double s=0.0; int i; for(i=0;i<=m;i++) s+=log(1.0*i); s=sqrt(s); return s; } 第三十套 1. 程序填空 函数fun的功能是:反形参a所指数组中的奇数 按原顺序依次存放到a[0]、a[1]、a [2]……中,把偶数从数组中删除,奇数个数通过函数值返回。例如:若a所指数组中的数据最初排列为:9、1、4、2、3、6、5、8、7,删除偶数后a所指数组中的数据为:9、1、3、5、7,返回值为5。 第一处 if(a[i]%2==1) 第二处 j++; 第三处 return j; 2. 程序修改 给定程序MODI1.C中函数fun的功能是:求出两个非零正整数的最大公约数,并作为函数值返回。 /**found**/ t=a;a=b;b=t; /**found**/ return (b); 3. 程序设计 假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:删除字符串中所有的*号。在编写函数时,不得使用C语言提供的字符串函数。 void fun(char *a) { int j=0; char *p=a; while(*p){ if(*p!=’*’) a[j++]=*p; p++; } a[j]=0; } 第三十一套 1. 程序填空 给定程序中,函数fun的功能是:在形参ss所指字符串数组中,删除所有串长超过k的字符串,函数返回所剩字符串的个数。Ss所指字符串数组中共有N个字符串,且串长小于M。 第一处 for(i=0;i 第三处 strcpy(ss[j++],ss[i]); 2. 程序修改 给定程序MODI1.C中函数fun的功能是:逐个比较p、q所指两个字符串对应位置中的字符,把ASCII值或相等的字符依次存放在c所指数组中,形成一个新的字符串。 /**found**/ int k=0; /**found**/ while(*p||*q) 3. 程序设计 假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:除了字符串前导*号之外,将串中其它*号全部删除。在编写函数时,不得使用C语言提供的字符串函数。函数fun中给出的语句仅供参考。 10 void fun(char *a) { int i=0,k; while(a[i]!==’*’)i++; k=i; while(a[i]!=’\\0’) { if(a[i]!=’*’) a[k++]=a[i]; i++; } a[k]=’\\0’; } 第三十二套 1. 程序填空 给定程序中已建立一个带头结点的单向链表,链表中的各结点按结点数据域中的数据递增有序链接。函数fun的功能是:把形参x的值放入一个新结点并插入到链表中,插入后各结点数据域的值仍保持递增有序。 第一处 s->data=x; 第二处 q=p; 第三处 q->next=s; 2. 程序修改 给定程序MODI1.C中函数fun的功能是:计算正整数num的各位上的数字之积。 /**found**/ long k=1; /**found**/ num/=10 3. 程序设计 请编写函数fun,它的功能是:计算n门课程的平均分,计算结果作为函数返回。 float fun(float *a,int n) { int i; float ave=0.0; for(i=0;i 第三十三套 1. 程序填空 给定程序中,函数fun的功能是:在形参ss所指字符串数组中,查找含有形参substr所指子串的所有字符串并输出,若没找到输出相应信息。Ss所指字符串数组中共有N个字符,且串长小于M。程序中库函数strstr(s1、s2)的功能是早s1串中查找s2子串,若没有,函数值为0,若有,为非0。 第一处 for(i=0;i 第二处 if(strstr(ss[i],substr)!=NULL) 第三处 if(find==0) 2. 程序修改