二级C语言上机改错题题型
计算机等级考试(NCRE)二级c语言改错题
计算机等级考试(NCRE)二级c语言搞错题1、给定程序MODI1.C中,函数fun的功能是求矩阵(二维数组)a[N][N]中每行的最小值,结果存放到数组b中。
请改正函数fun中指定部位的错误,使它能得出正确的结果。
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。
#include <stdio.h>#define N 4void fun(int a[][N], int b[]){ int i, j;for (i=0; i<N; i++){/**********found**********/b[i] = a[i][0];/**********found**********/for (j=1; j<=N-1; j++)/**********found**********/if ( b[i] > a[i][j] )b[i] = a[i][j];}}main(){ int a[N][N]={{1,4,3,2},{8,6,5,7},{11,10,12,9},{13,16,14,15}},b[N]; int i;fun(a,b);for (i=0; i<N; i++) printf("%d,", b[i]);printf("\n");}2、给定程序MODI1.C中规定输入的字符串全部为字母,fun函数的功能是:统计a所指字符串中每个字母在字符串中出现的次数(统计时不区分大小写),并将出现次数最高的字母输出(如果有多个相同,输出一个即可)。
例如对于字符串:dadbcdbabdb,对应的输出应为:b或d。
请改正函数fun中指定部位的错误,使它能得出正确的结果。
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。
#include<stdio.h>#include <stdio.h>#include <string.h>void fun(char a[]){ int b[26], i, n,max;for (i=0; i<26; i++)/**********found**********/b[i] = 0;n= strlen(a);for (i=0; i<n; i++)if (a[i] >='a' && a[i]<='z')/**********found**********/b[a[i] - 'a']++;else if (a[i] >='A' && a[i]<='Z')b[a[i] -'A']++;max = 0;for (i=1; i<26; i++)/**********found**********/if (b[max] < b[i])max=i;printf("出现次数最多的字符是 : %c\n", max + 'a');}main( ){ char a[200];printf("请输入一个待统计的字符串 : "); scanf("%s", a);fun(a);}3、给定程序MODI1.C中,函数fun()的功能是统计s所指一维数组中0的个数(存在变量zero中)和1的个数(存在变量one中),并输出结果。
计算机二级上机C改错例题
m ,计算如下公y=1+1/(2*2)+1/(3*3)+1/(4*4)+…+1/(m*m)的值。
例如,若m=5,则应输出:1.463611。
double fun(int m) {double y=1.0;int i;for(i=2;i<=m;i++)y+=1.0/(i*i);return(y);}2根据形参m ,计算下列公式的值。
t=1-1/2+1/3-1/4+…+(-1)(m+1)/m 例如,若输入5,则应输出0.783333。
double fun(int m){double t=1.0,j=1.0;int i; for(i=2;i<=m;i++){j=-1*j;t+=j/i;}return t;}3根据整型参数m ,计算如下公式的值。
y=1/(100×100)+1/(200×200)+1/(300×300)+…+1/(m ×m)。
例如,若m=2000,则应输出0.000160。
double fun (int m) {double y=0, d;int i; for(i=100;i<=m;i+=100){d=(double)i*(double)i;y+=1.0/d;}return(y);}4根据以下公式求π的值。
例如,给eps 输入0.0005时,应当输出Pi=3.140578。
π/2=1+1/3+1/3*2/5+1/3*2/5*3/7+…double fun(double eps) {double s,t; int n=1;s=0.0;t=1.0;while(t>=eps){s+=t;t=t*n/(2*n+1);n++;}return (s*2);}5根据形参m,计算下列公式的值。
t=1+1/2+1/3+1/4+…+1/m 。
例如,若输入5,则应输出2.283333。
double fun(int m) {double t=1.0;int i;for(i=2;i<=m;i++)t+=1.0/i; m ,计算如下公式的根号(2)+1/根号(3)+……1/根号(n) 例如,若m 中的值为:5,则应输出:3.231671 #include <math.h> double fun(int m) {int i;double t,y=0;for(i=1;i<=m;i++){t=1/sqrt(i);y=y+t;}return y;}7根据整型形参m 的值,计算如下公式的值。
国家二级c语言上机考试分类程序改错
改错1#include <stdio.h>/************found************/void fun ( int n ){ int a, b, c, k; double s;s = 0.0; a = 2; b = 1;for ( k = 1; k <= n; k++ ) {/************found************/s = s + (Double)a / b;c = a; a = a + b; b = c;}return s;}main( ){ int n = 5;printf( "\nThe value of function is: %lf\n", fun ( n ) ); }【参考答案】(1)double fun(int n)(2)s=s+(double)a/b;2#include <stdio.h>int fun (char *str,char *substr){ int i,j,k,num=0;/************found************/for(i = 0, str[i], i++)for(j=i,k=0;substr[k]==str[j];k++,j++)/************found************/If(substr[k+1]=='\0'){ num++;break;}return num;}main(){char str[80],substr[80];printf("Input a string:") ;gets(str);printf("Input a substring:") ;gets(substr);printf("%d\n",fun(str,substr));}【参考答案】(1)for(i=0;str[i];i++)(2)if(substr[k+1]== ′\0′)3#include <stdio.h>int fun(int *x,int y){int t ;/**************found**************/ t = x ; x = y ;/**************found**************/ return(y) ;}main(){int a = 3, b = 8 ;printf("%d %d\n", a, b) ;b = fun(&a, b) ;printf("%d %d\n", a, b) ;}【参考答案】(1)t = *x ; *x = y ;(2)return(t) ;或return t;4#include <stdio.h>int fun(int a,int b){ int r,t;if(a<b) {/************found************/t=a; b=a; a=t;}r=a%b;while(r!=0){ a=b; b=r; r=a%b; }/************found************/return(a);}main(){ int num1, num2,a;printf("Input num1 num2: "); scanf("%d%d",&num1,&num2);printf("num1= %d num2= %d\n\n",num1,num2);a=fun(num1,num2);printf("The maximun common divisor is %d\n\n",a);}【参考答案】(1) t=a;a=b;b=t;(2) return(b);或return b;5、#include <stdio.h>void fun (long s, long *t){ int d;long sl=1;/************found************/t = 0;while ( s > 0){ d = s%10;/************found************/if (d%2 == 0){ *t = d * sl + *t;sl *= 10;}s /= 10;}}main(){ long s, t;printf("\nPlease enter s:"); scanf("%ld", &s);fun(s, &t);printf("The result is: %ld\n", t);}【参考答案】(1)*t=0;(2)if(d%2!=0)或if(d%2==1)6#include <stdio.h>long fun(int g){/**********found**********/switch(g);{ case 0: return 0;/**********found**********/case 1 ;case 2 : return 1 ;}return( fun(g-1)+fun(g-2) );}main(){ long fib; int n;printf("Input n: "); scanf("%d",&n); printf("n = %d\n",n);fib=fun(n);printf("fib = %d\n\n",fib);}【参考答案】(1) 去掉分号(2) case 1:case 2:return 1;7#include <stdio.h>void fun(char *p, char *b){ int i, k=0;while(*p){ i=1;while( i<=3 && *p ) {/**********found**********/b[k]=p;k++; p++; i++;}if(*p){/**********found**********/b[k++]=" ";}}b[k]='\0';}main(){ char a[80],b[80];printf("Enter a string: "); gets(a);printf("The original string: "); puts(a);fun(a,b);printf("\nThe string after insert space: "); puts(b); printf("\n\n"); }【参考答案】(1) b[k]=*p;(2) b[k]=′′;k++;8#include <stdio.h>#include <string.h>char* fun( char tt[] ){int i;for( i = 0; tt[i]; i++ )/**********found***********/if(( 'a' <= tt[i] )||( tt[i] <= 'z' ) )/**********found***********/tt[i] += 32;return( tt );}main( ){char tt[81];printf( "\nPlease enter a string: " );gets( tt );printf( "\nThe result string is:\n%s", fun( tt ) ); }【参考答案】(1)if(( tt[i]>=a′)&&( tt[i] <= ′z′)(2)tt[i]-=32;9#include <stdio.h>#include <string.h>#define MAXLINE 20fun ( char *pstr[6]){ int i, j ;char *p ;for (i = 0 ; i < 5 ; i++ ) {/**************found**************/for (j = i + 1, j < 6, j++){if(strcmp(*(pstr + i), *(pstr + j)) > 0){p = *(pstr + i) ;/**************found**************/*(pstr + i) = pstr + j ;*(pstr + j) = p ;}}}}main( ){ int i ;char *pstr[6], str[6][MAXLINE] ;for(i = 0; i < 6 ; i++) pstr[i] = str[i] ;printf( "\nEnter 6 string(1 string at each line): \n" ) ;for(i = 0 ; i < 6 ; i++) scanf("%s", pstr[i]) ;fun(pstr) ;printf("The strings after sorting:\n") ;for(i = 0 ; i < 6 ; i++) printf("%s\n", pstr[i]) ;}【参考答案】(1)for (j = i + 1; j < 6; j++)(2)*(pstr + i) = *(pstr + j) ;10#include <stdio.h>long fun (long num){/************found************/long k;do{ k*=num%10 ;/************found************/num\=10 ;} while(num) ;return (k) ;}main( ){ long n ;printf("\nPlease enter a number:") ; scanf("%ld",&n) ; printf("\n%ld\n",fun(n)) ;}【参考答案】(1)long k=1;(2)num /=10;11#include <stdio.h>void fun(float *a,float *b,float *c){/**********found**********/float *k;if( *a<*b ){ k=*a; *a=*b; *b=k; }/**********found**********/if( *a>*c ){ k=*c; *c=*a; *a=k; }if( *b<*c ){ k=*b; *b=*c; *c=k; }}main(){ float a,b,c;printf("Input a b c: "); scanf("%f%f%f",&a,&b,&c);printf("a = %4.1f, b = %4.1f, c = %4.1f\n\n",a,b,c);fun(&a,&b,&c);printf("a = %4.1f, b = %4.1f, c = %4.1f\n\n",a,b,c);}【参考答案】(1)float k;(2)if(*a< *c)12#include <stdio.h>long fun (int a, int n){ int j ;/**************found**************/long s = 0, t = 1 ;for ( j = 0 ; j < n ; j++)t = t * 10 + a ;s = t ;for ( j = 1 ; j < n ; j++) {/**************found**************/t = t % 10 ;s = s - t ;}return(s) ;}main( ){ int a, n ;printf( "\nPlease enter a and n:") ;scanf( "%d%d", &a, &n ) ;printf( "The value of function is: %ld\n", fun ( a, n ) ); }【参考答案】(1)long s=0, t=0;(2)t=t/10;13#include <stdio.h>long fun (int a, int n){ int j ;/**************found**************/long s = 0, t = 1 ;for ( j = 0 ; j < n ; j++)t = t * 10 + a ;s = t ;for ( j = 1 ; j < n ; j++) {/**************found**************/t = t % 10 ;s = s - t ;}return(s) ;}main( ){ int a, n ;printf( "\nPlease enter a and n:") ;scanf( "%d%d", &a, &n ) ;printf( "The value of function is: %ld\n", fun ( a, n ) ); }【参考答案】(1)long s=0, t=0;(2)t=t/10;14#include <stdio.h>int fun( int *b ){ int k,a1,a2,i=0;for(k=10; k<=55; k++) {/************found************/a2=k/1O;a1=k-a2*10;if((k%3==0 && a2==5)||(k%3==0 && a1==5)){ b[i]=k; i++; }}/************found************/return k;}main( ){ int a[100],k,m;m=fun( a );printf("The result is :\n");for(k=0; k<m; k++) printf("%4d",a[k]); printf("\n"); }【参考答案】(1)a2=k/10;(2)return i;15#include <stdio.h>/************found************/void fun (char a){ if ( *a ){ fun(a+1) ;/************found************/printf("%c" *a) ;}}main( ){ char s[10]="abcd";printf("处理前字符串=%s\n处理后字符串=", s);fun(s); printf("\n") ;}【参考答案】(1)void fun(char *a)(2)printf("%c" ,*a) ;16#include <stdio.h>int fun( char *p ){ int n;/**********found**********/n= *P-'o';p++;while( *p!=0 ) {/**********found**********/n=n*8+*P-'o';p++;}return n;}main(){ char s[6]; int i; int n;printf("Enter a string (Ocatal digits): "); gets(s);if(strlen(s)>5){ printf("Error: String too longer !\n\n");exit(0); } for(i=0; s[i]; i++)if(s[i]<'0'||s[i]>'7'){ printf("Error: %c not is ocatal digits!\n\n",s[i]);exit(0); } printf("The original string: "); puts(s);n=fun(s);printf("\n%s is convered to integer number: %d\n\n",s,n);}【参考答案】(1)n= *p-′0′;(2)n=n*8+*p-′0′;17#include <stdio.h>void fun (long s, long *t){ int d;long sl=1;*t = 0;while ( s > 0){ d = s%10;/************found************/if (d%2=0){ *t=d* sl+ *t;sl *= 10;}/************found************/s \= 10;}}main(){ long s, t;printf("\nPlease enter s:"); scanf("%ld", &s);fun(s, &t);printf("The result is: %ld\n", t);}【参考答案】(1)if(d%2==0)(2)s/=10;18#include <stdio.h>#include <math.h>int fun( int high ){ int sum = 0, n=0, j, yes;/************found************/while ((high >= 2) && (n < 10){ yes = 1;for (j=2; j<=high/2; j++ )if (high % j ==0 ){/************found************/yes=0; break}if (yes) { sum +=high; n++; }high--;}return sum ;}main ( ){printf("%d\n", fun (100));}【参考答案】(1)while((high>=2) && (n<10))(2)yes=0; break;19#include <stdio.h>void fun( char *s ){ int i,j;for(i=j=0; s[i]!='\0'; i++)if(s[i]!='c')/************found************/s[j]=s[i];/************found************/s[i]=0;}main(){ char s[80];printf("Enter a string: "); gets(s);printf("The original string: "); puts(s);fun(s);printf("The string after deleted : "); puts(s);printf("\n\n"); }【参考答案】(1)s[j++]=s[i];或{s[j]=s[i];j++;}(2)s[j]= ′\0′;20#include <stdio.h>/************found************/void fun (long s, long t){ long sl=10;*t = s % 10;while ( s > 0){ s = s/100;*t = s%10 * sl + *t;/************found************/sl = sl*100;}}main(){ long s, t;printf("\nPlease enter s:"); scanf("%ld", &s);fun(s, &t);printf("The result is: %ld\n", t);}【参考答案】(1)void fun(long s,long *t)(2)s1=s1*10;21#include <stdlib.h>#include <conio.h>#include <stdio.h>#include <math.h>/*************found**************/ f(double x){if(x==0.0||x==2.0)return 0.0;else if(x<0.0)return(x-1)/(x-2);elsereturn(x+1)/(x-2);}double fun(int n){int i; double s=0.0,y;for(i=-n; i<=n;i++){ y=f(1.0*i); s+=y;}/*************found**************/ return s}void main(){ system("CLS");printf("%f\n", fun(5));}【参考答案】(1)double f(double x)(2)return s ;22#include <stdio.h>/************found************/ fun(int x, y, z ){ int j,t ,n ,m;j = 1 ;t=j%x;m=j%y ;n=j%z;while(t!=0||m!=0||n!=0){ j = j+1;t=j%x;m=j%y;n=j%z;}/************found************/return i;}main( ){ int x1,x2,x3,j ;printf("Input x1 x2 x3: "); scanf("%d%d%d",&x1,&x2,&x3);printf("x1=%d, x2=%d, x3=%d \n",x1,x2,x3);j=fun(x1,x2,x3);printf("The minimal common multiple is : %d\n",j);}【参考答案】(1)fun(int x,int y, int z)或int fun(int x,int y,int z)(2)return j;23#include <stdio.h>#include <string.h>void fun (char *s, char *t1, char *t2 , char *w){char *p , *r, *a;strcpy( w, s );while ( *w ){ p = w; r = t1;/************found************/while ( r )if ( *r == *p ) { r++; p++; }else break;if ( *r == '\0' ){ a = w; r = t2;while ( *r ){/************found************/*a = *r; a++; r++}w += strlen(t2) ;}else w++;}}main(){char s[100], t1[100], t2[100], w[100];printf("\nPlease enter string S:"); scanf("%s", s); printf("\nPlease enter substring t1:"); scanf("%s", t1); printf("\nPlease enter substring t2:"); scanf("%s", t2); if ( strlen(t1)==strlen(t2) ) {fun( s, t1, t2, w);printf("\nThe result is : %s\n", w);}else printf("Error : strlen(t1) != strlen(t2)\n");}【参考答案】(1)while( *r)(2){*a=*r;a++;r++;}24#include <stdio.h>#include <string.h>#define N 5#define M 81/**********found**********/fun(char (*sq)[M]){ int i; char *sp;sp=sq[0];for(i=0;i<N;i++)if(strlen( sp)<strlen(sq[i]))sp=sq[i] ;/**********found**********/return sq;}main(){ char str[N][M], *longest; int i;printf("Enter %d lines :\n",N);for(i=0; i<N; i++) gets(str[i]);printf("\nThe N string :\n",N);for(i=0; i<N; i++) puts(str[i]);longest=fun(str);printf("\nThe longest string :\n"); puts(longest); }【参考答案】(1)char *fun(char (*sq)[M])(2)return sp;25#include <stdio.h>#define N 10/************found************/void fun(int a[], int m ){ int low=0,high=N-1,mid;while(low<=high){ mid=(low+high)/2;if(m<a[mid])high=mid-1;/************found************/else If(m > a[mid])low=mid+1;else return(mid);}return(-1);}main(){ int i,a[N]={-3,4,7,9,13,45,67,89,100,180 },k,m;printf("a数组中的数据如下:");for(i=0;i<N;i++) printf("%d ", a[i]);printf("Enter m: "); scanf("%d",&m);k=fun(a,m);if(k>=0) printf("m=%d,index=%d\n",m,k);else printf("Not be found!\n");}【参考答案】(1)int fun(int a[],int m)或fun(int a[],int m)(2)else if(m>a[mid])26#include <stdio.h>/************found************/void fun (long s, long t){ long sl=10;s /= 10;*t = s % 10;/************found************/while ( s < 0){ s = s/100;*t = s%10*sl + *t;sl = sl * 10;}}main(){ long s, t;printf("\nPlease enter s:"); scanf("%ld", &s);fun(s, &t);printf("The result is: %ld\n", t);}【参考答案】(1)void fun(long s,long *t)(2)while(s>0)27#include <stdio.h>#include <math.h>/**********found**********/fun(double a, dounle x0){ double x1, y;x1=(x0+ a/x0)/2.0;/**********found**********/if( fabs(x1-x0)<0.00001 )y=fun(a,x1);else y=x1;return y;}main( ){ double x;printf("Enter x: "); scanf("%lf",&x);printf("The square root of %lf is %lf\n",x,fun(x,1.0)); }【参考答案】(1)double fun(double a,double x0)(2)if(fabs(x1-x0)>=0.00001)28#include <stdio.h>#define N 20void fun(int a[], int n){ int i, j, t, p;for (j = 0 ;j < n-1 ;j++) {/************found************/p = jfor (i = j;i < n; i++)if(a[i] < a[p])/************found************/p = j;t = a[p] ; a[p] = a[j] ; a[j] = t;}}main(){int a[N]={9,6,8,3,-1},i, m = 5;printf("排序前的数据:") ;for(i = 0;i < m;i++) printf("%d ",a[i]); printf("\n");fun(a,m);printf("排序后的数据:") ;for(i = 0;i < m;i++) printf("%d ",a[i]); printf("\n");}【参考答案】(1)p=j ;(2)p=i;29#include <stdio.h>#include <math.h>#include <stdlib.h>/************found************/#define FU(m,n) ((m/n))float fun(float a,float b,float c){ float value;value=FU(a+b,a-b)+FU(c+b,c-b);/************found************/Return(Value);}main(){ float x,y,z,sum;printf("Input x y z: ");scanf("%f%f%f",&x,&y,&z);printf("x=%f,y=%f,z=%f\n",x,y,z);if (x==y||y==z){printf("Data error!\n");exit(0);} sum=fun(x,y,z);printf("The result is : %5.2f\n",sum);}【参考答案】(1)#define FU(m,n) (m)/(n)(2)return (value);30#include <stdio.h>#include <string.h>#define N 80void insert(char *aa){ int i,j,n; char ch;/**********found**********/n=strlen[ aa ];for( i=1; i<n ;i++ ) {/**********found**********/c=aa[i];j=i-1;while ((j>=0) && ( ch<aa[j] )){ aa[j+1]=aa[j];j--;}aa[j+1]=ch;}}main( ){ char a[N]="QWERTYUIOPASDFGHJKLMNBVCXZ";printf ("The original string : %s\n", a);insert(a) ;printf("The string after sorting : %s\n\n",a );}【参考答案】(1)n=strlen( aa ) ;(2)ch=aa[i];31.#include <stdlib.h>#include <conio.h>#include <stdio.h>int fun(int m){ int k=2;while (k<=m&&(m%k))/*************found**************/k++/*************found**************/if(m=k)return 1;else return 0;}void main(){ int n;system("CLS");printf("\nPlease enter n: ");scanf("%d",&n);if(fun(n)) printf("YES\n");else printf("NO!\n");}【参考答案】(1)正确:k++;(2)正确:if(m==k)32.#include <stdio.h>#include <string.h>/************found************/void fun (char s, char t){int i, d;d = strlen(s);for (i = 0; i<d; i++) t[i] = s[i];for (i = 0; i<d; i++) t[d+i] = s[d-1-i];/************found************/t[2*d-1] = '\0';}main(){char s[100], t[100];printf("\nPlease enter string S:"); scanf("%s", s);fun(s, t);printf("\nThe result is: %s\n", t);}【参考答案】(1)void fun ( char *s , char *t )(2)t[2*d]='\0';或t[d+i]='\0';或t[2*d]=0;或t[d+i]=0;33.#include <stdio.h>double fun ( int m ){ double y = 1.0 ;int i;/**************found**************/for(i = 2 ; i < m ; i++)/**************found**************/y += 1 / (i * i) ;return( y ) ;}main( ){ int n = 5 ;printf( "\nThe result is %lf\n", fun ( n ) ) ;}【参考答案】(1)for(i=2;i<=m;i++)(2)y+=1.0/(i*i);或y+=(double)1.0/(i*i)34.#include <stdlib.h>#include <conio.h>#include <stdio.h>#include <string.h>#define N 80void fun(char *s, char t[]){int i, j=0;for(i=0; i<(int)strlen(s);i++)/*************found**************/if(i%2 && s[i]%2==0)t[j++]=s[i] ;/*************found**************/t[i]='\0';}void main(){char s[N], t[N];system("CLS");printf("\nPlease enter string s :");gets(s);fun(s,t);printf("\nThe result is :%s\n",t);}【参考答案】(1)if(i%2 || s[i]%2==0) 或 if(i%2 !=0 || s[i]%2==0)(2)t[j]= ′\0′; 或 t[j]=0;35.#include <stdio.h>#define N 20int fun(int *a,int n,int x){ int p=0,i;a[n]=x;while( x!=a[p] )p=p+1;/**********found**********/if(P==n) return -1;else{ for(i=p;i<n-1;i++)/**********found**********/a[i+1]=a[i];return n-1;}}main(){ int w[N]={-3,0,1,5,7,99,10,15,30,90},x,n,i;n=10;printf("The original data :\n");for(i=0;i<n;i++) printf("%5d",w[i]);printf("\nInput x (to delete): "); scanf("%d",&x);printf("Delete : %d\n",x);n=fun(w,n,x);if ( n==-1 ) printf("***Not be found!***\n\n");else{ printf("The data after deleted:\n");for(i=0;i<n;i++) printf("%5d",w[i]);printf("\n\n");}}【参考答案】(1)if(p==n) return -1;(2)a[i]=a[i+1];36.#include <stdlib.h>#include <conio.h>#include <string.h>#include <stdio.h>#define N 80int fun(char *s,char *t){ int n;char *p, *r;n=0;p=&s[0];/*************found**************/*r=t;while(*p){if(*r==*p){r++;if(*r=='\0'){n++;/*************found**************/【1】;}}p++;}return n;}void main(){char a[N],b[N]; int m;system("CLS");printf("\nPlease enter string a: ");gets(a);printf("\nPlease enter substring b: ");gets(b);m=fun(a,b);m=printf("\nThe result is :m=%d\n",m);}【参考答案】(1)r=t;(2)应填:r=t;或r=&t[0];37.#include <math.h>#include <stdio.h>float fun ( float num ){ int s ;float n, t, pi ;t = 1 ; pi = 0 ; n = 1 ; s = 1 ;/**************found**************/ while(t >= num){pi = pi + t ;n = n + 2 ;s = -s ;/**************found**************/ t = s % n ;}pi = pi * 4 ;return pi ;}main( ){ float n1, n2 ;printf("Enter a float number: ") ;scanf("%f", &n1) ;n2 = fun(n1) ;printf("%6.4f\n", n2) ;}【参考答案】(1)while(fabs(t)>=num)(2)t=s/n;38.#include <stdlib.h>#include <stdio.h>#include <ctype.h>#include <conio.h>void fun(char *s)/*************found**************/{ while(*s!= '@'){ if(*s>='A'&&*s<='Z'||*s>='a'&&*s<='z') {if(*s=='Z') *s='A';else if(*s=='z') *s='a';else *s+=1;}/*************found**************/(*s)++;}}void main(){ char s[80];system("CLS");printf("\n Enter a string with length<80:\n\n"); gets (s);printf("\n The string:\n\n");puts(s);fun(s);printf("\n\n The Cords :\n\n");puts(s);}【参考答案】(1)while(*s)或while(*s!='\0')(2)s++;39.#include <stdlib.h>#include <stdio.h>#include <conio.h>void fun(char *s){int i,j;for(i=0,j=0; s[i]!= '\0'; i++)if(s[i]>= '0'&&s[i]<= '9')/*************found**************/s[j]=s[i];/*************found**************/s[j]=”\0”;}void main(){char item[80];system("CLS");printf("\nEnter a string: ");gets(item);printf("\n\nThe string is:%s\n",item);fun(item);printf("\n\nThe string of changing is :%s\n",item); }【参考答案】(1)s[j++]=s[i];(2)s[j]= '\0';40.#include <stdio.h>double fun ( int x[]){/************found************/int sum = 0.0;int c=0, i=0;while (x[i] != 0){ if (x[i] > 0) {sum += x[i]; c++; }i++;}/************found************/sum \= c;return sum;}main( ){ int x[1000]; int i=0;printf( "\nPlease enter some data (end with 0): " );do{ scanf("%d", &x[i]); }while (x[i++] != 0);printf("%f\n", fun ( x ));}【参考答案】(1)double sum=0.0;(2)sum/=c;41.#include <stdio.h>#include <string.h>void fun (char *s, char *t1, char *t2 , char *w){char *p , *r, *a=s;strcpy( w, s );/************found************/while ( w ){ p = w; r = t1;while ( *r )/************found************/IF ( *r == *p ){ r++; p++; }else break;if ( *r == '\0' ) a = w;w++;}r = t2;while ( *r ){ *a = *r; a++; r++; }}main(){char s[100], t1[100], t2[100], w[100];printf("\nPlease enter string S:"); scanf("%s", s); printf("\nPlease enter substring t1:"); scanf("%s", t1); printf("\nPlease enter substring t2:"); scanf("%s", t2); if ( strlen(t1)==strlen(t2) ){ fun( s, t1, t2, w);printf("\nThe result is : %s\n", w);}else printf("\nError : strlen(t1) != strlen(t2)\n");}【参考答案】(1)while (*w)(2)if ( *r ==*p )42.#include <stdlib.h>#include <conio.h>#include <string.h>#include <stdio.h>#include <malloc.h>#define N 10typedef struct ss{ char num[10];int s;} STU;STU *fun(STU a[], int m){ STU b[N],*t;int i, j,k;/*************found**************/*t=calloc(m,sizeof(STU));for(i=0;i<N;i++) b[i]=a[i];for(k=0;k<m;k++){ for (i=j=0;i<N;i++)if(b[i].s>b[j].s) j=i;/*************found**************/t[k].num=b[j].num;t[k].s=b[j].s;b[j].s=0;}return t;}outresult(STU a[],FILE *pf){ int i;for(i=0;i<N;i++)fprintf(pf, "No=%s Mark=%d\n ",a[i].num, a[i].s);fprintf(pf, "\n\n ");}void main(){ STU a[N]={{ "A01 ",81},{ "A02 ",89},{ "A03 ",66},{ "A04 ",87},{ "A05 ",77}, { "A06 ",90},{ "A07 ",79},{ "A08 ",61},{ "A09 ",80},{ "A10 ",71}}; STU *pOrder;int i, m;system("CLS");printf("*****THE RESULT*****\n");outresult(a,stdout);printf("\nGive the number of the students who have better score: ");scanf("%d",&m);while(m>10){ printf("\nGive the number of the students who have better score: "); scanf("%d",&m);}pOrder=fun(a,m);printf("***** THE RESULT*****\n");printf("The top :\n");for(i=0;i<m;i++)printf("%s %d\n",pOrder[i].num, pOrder[i].s);free(pOrder);}【参考答案】(1)t=calloc(m,sizeof(STU));(2)t[k]=b[j];43.#include <stdio.h>#include <math.h>double funx(double x){ return(2*x*x*x-4*x*x+3*x-6); }double fun( double m, double n){/************found************/int r;r=(m+n)/2;/************found************/while(fabs(n-m)<0.001){ if(funx(r)*funx(n)<0) m=r;else n=r;r=(m+n)/2;}return r;}main( ){ double m,n, root;printf("Enter m n : \n"); scanf("%lf%lf",&m,&n);root=fun( m,n );printf("root = %6.3f\n",root);}【参考答案】(1)double r ;(2)while (fabs(n-m) >0.001)44.#include <stdio.h>#include <string.h>void fun (char *s, char *t){/************found************/int i;sl = strlen(s);for (i=0; i<sl; i++)/************found************/t[i] = s[sl-i];for (i=0; i<=sl; i++)t[sl+i] = s[i];t[2*sl] = '\0';}main(){ char s[100], t[100];printf("\nPlease enter string s:"); scanf("%s", s);fun(s, t);printf("The result is: %s\n", t);}【参考答案】(1)int i, s1;(2)t[i]=s[s1-i-1];45.#include <math.h>#include <stdio.h>double fun(double eps){ double s,t; int n=1;s=0.0;/************found************/t=0;while( t>eps){ s+=t;t=t * n/(2*n+1);n++;}/************found************/return(s);}main(){ double x;printf("\nPlease enter a precision: "); scanf("%lf",&x);printf("\neps=%lf, Pi=%lf\n\n",x,fun(x));}【参考答案】(1)t=1.0;(2)return(s*2);46.#include <stdio.h>#include <stdlib.h>fun ( int n, int *a ){ int i, j, p, t;for ( j = 0; j<n-1 ; j++ ){ p = j;/************found************/for ( i=j+1; i<n-1 ; i++ )if ( a[p]>a[i] )/************found************/t=i;if ( p!=j ){ t = a[j]; a[j] = a[p]; a[p] = t; }}}putarr( int n, int *z ){ int i;for ( i = 1; i <= n; i++, z++ ){ printf( "%4d", *z );if ( !( i%10 ) ) printf( "\n" );} printf("\n");}main(){ int aa[20]={9,3,0,4,1,2,5,6,8,10,7}, n=11;printf( "\n\nBefore sorting %d numbers:\n", n ); putarr( n, aa );fun( n, aa );printf( "\nAfter sorting %d numbers:\n", n ); putarr( n, aa );。
全国计算机等级考试_二级C语言上机考试题库及答案-改错
6.2给定程序MODI1.C中函数fun的功能是:将字符串中的字符按逆序输出,但不改变字符串中的内容。
例如,若字符串为abcd,则应输出:dcba.
答案:第一处fun(char a)改为fun(char*a) 第二处printf(“%c“*a)改为 printf(“%”,*a)
13.2给定程序MODI1。C中函数fun的功能是:求k!(k<13),所求阶乘的值作为函数值返回。例如:若k=10,则应输出:3628800请改正程序中的错误。
第一处:if k>0改为if(k>0)第二处:if(k=0)改为if(k==0)
14.2给定程序MODI1。C中函数fun的功能是:将m(1<=m<=10)个字符串连接起来,组成一个新串,放入pt所指存储区中。
答案:1 将t=1改为t=0 2 将t=t%10改为t=t/10
26.2给定函数功能是:用下面的公式求 的近似值,直到最后一项的绝对值小于指定的数(参数num)为止:
例如,输入0.0001,则程序输出3.1414
答案:1将(t>=num)改为((fabs(t))>=num) 2 将t=s%n改为t=s/n
28.2给定程序中,函数fun的功能是:计算并输出high以内最大的10个素数之和。high的值由主函数传给fun函数。若high的值为100,则函数的值为732
答案: 第一处:while((high>=2)&&(n<10)改为 while((high>=2)&&(n<10))
第二处:yes=0;break 改为yes=0;break;
国家计算机C语言二级考试改错题库
1 下列给定程序中,函数fun 的功能是:计算S=f(-n)+f(-n+1)+…+f(0)+f(1)+f(2)+…f(n)的值。
例如,当n 为5时,函数值应为10.407143。
f(x)函数定义如下:f(x)=(1)(2)0002(1)(2)0x x x x x x x x ⎧+/->⎪==⎨⎪-/-<⎩或请改正程序中的错误,使它能得出正确的结果。
注意:不要改动main 函数,不得增行或删行,也不得更改程序的结构。
试题程序:#include <stdlib.h> #include <conio.h> #include <stdio.h> #include <math.h>/*************found**************/ f(double x)2 下列给定程序中,fun 函数的功能是:根据形参m,计算下列公式的值:t=1+1/2+1/3+1/4+…+1/m例如,若输入5,则应输出2.283333。
3 下列给定程序中,函数fun 的功能是:分别统计字符串中大写字母和小写字母的个数。
例如,给字符串s 输入:AaaaBBb123CCccccd,则应输出结果:upper=5,lower=9。
4 下列给定程序中函数fun 的功能是:计算正整数num 各位上的数字之积。
例如,若输入252,则输出应该是20。
若输入202,则输出应该是0。
5 下列给定程序中函数fun 的功能是:计算n!。
例如,给n 输入5,则输出120.000000。
6 下列给定的程序中,函数fun 的功能是:计算并输出k 以内最大的10个能被13或17整除的自然数之和。
k 的值由主函数传入,若k 的值为500,则函数的值为4622。
7 下列给定程序中,函数fun()的功能是:根据整型形参m 的值,计算如下公式的值:t=1-1/(22)1/(33)...1/()m m ⨯-⨯--⨯8 在主函数中从键盘输入若干个数放入数组中,用0结束输入并放在最后一个元素中。
全国计算机二级C语言程序改错题(-100%全中必过)
目录题目一前N项和问题 (3)题目二SS字符串问题 (4)题目三变量互换问题1 (4)题目三变量互换问题2 (5)题目三变量互换问题3 (5)题目四最大公约数问题 (6)题目五长数变短数1 (7)题目五长数变短数2 (7)题目五长数变短数3 (8)题目五长数变短数4 (9)题目五长数变短数5 (9)题目五长数变短数6 (10)题目五长数变短数7 (11)题目五长数变短数8 (11)题目五长数变短数9 (12)题目六斐波拉契数列 (13)题目七链表1 (14)题目七链表2 (15)题目七链表3 (16)题目七链表4 (17)题目八非素数问题 (19)题目九排序问题1 (19)题目九排序问题2 (20)题目九排序问题3 (21)题目九排序问题4 (22)题目九排序问题5 (23)题目九排序问题6 (24)题目九排序问题6 (25)题目九排序问题7 (26)题目十平均值问题1 (26)题目十平均值问题2 (27)题目十平均值问题3 (28)题目十平均值问题4 (29)题目十平均值问题5 (30)题目十一字符串连接1 (30)题目十一字符串连接2 (31)题目十一字符串连接3 (32)题目十一字符串连接4 (32)题目十二求和问题1 (33)题目十二求和问题2 (34)题目十二求和问题3 (35)题目十二求和问题4 (36)题目十二求和问题6 (37)题目十二求和问题7 (38)题目十二求和问题8 (39)题目十二求和问题9 (39)题目十二求和问题10 (40)题目十二求和问题11 (41)题目十二求和问题12 (42)题目十二求和问题13 (42)题目十二求和问题14 (43)题目十二求和问题15 (44)题目十二求和问题16 (44)题目十二求和问题17 (45)题目十二求和问题18 (45)题目十二求和问题19 (46)题目十三整数问题 (47)题目十四字符串逆置 (48)题目十五进制转换1 (48)题目十五进制转换2 (49)题目十六素数问题1 (50)题目十六素数问题2 (50)题目十六素数问题3 (51)题目十六素数问题4 (52)题目十六素数问题5 (53)题目十七删除字符串中指定项1 (53)题目十七删除字符串中指定项2 (54)题目十八最小公倍数问题 (55)题目十九字符串替换问题1 (55)题目十九字符串替换问题2 (56)题目二十找最长字符串 (57)题目二十一数组问题1 (58)题目二十一数组问题2 (59)题目二十一数组问题3 (60)题目二十二求平方根问题 (61)题目二十三短字符串变长字符串1 (61)题目二十三短字符串变长字符串2 (62)题目二十三短字符串变长字符串3 (63)题目二十三短字符串变长字符串4 (64)题目二十四字符串s问题1 (64)题目二十四字符串s问题2 (65)题目二十四字符串s问题3 (66)题目二十五求方程的根 (67)题目二十六求阶乘1 (68)题目二十六求阶乘2 (69)题目二十七方阵问题 (70)题目二十八查找字符串中某元素的数目 (71)题目二十九最大值问题1 (72)题目二十九最大值问题2 (72)题目二十九最大值问题3 (73)题目三十大小写转换1 (74)题目三十大小写转换2 (75)题目三十大小写转换3 (76)题目三十一:计算数字位数的问题1 (77)题目三十一:计算数字位数的问题2 (78)题目三十一:计算数字位数的问题3 (79)题目三十一:计算数字位数的问题4 (80)题目三十二统计字母数字个数问题1 (81)题目三十二统计字母数字个数问题2 (82)题目三十二统计字母数字个数问题3 (83)题目三十二统计字母数字个数问题4 (83)题目三十三对角线问题 (84)题目三十四比较字符串大小 (85)题目一前N项和问题.下列给定程序中函数fun的功能是:求出如下分数序列的前n项之和。
计算机二级C语言上机改错题题库
南开二级C语言上机100题(从搜狐网整理) (3)1、改错3 (3)2、改错4 (3)3、改错5 (4)4、改错6 (5)5、改错8(2004.7.27) (5)6、改错9(2004.7.27) (6)7、改错13(8.4) (7)8、改错14(8.4) (8)9、改错15(8.5) (8)10、改错17(8.5) (9)11、改错19(8.5) (10)12、改错20(8.5) (10)13、改错21 (11)14、改错22 (13)15、改错23 (13)16、改错24 (14)17、改错25 (15)18、改错26 (16)19、改错27 (16)20、改错28 (17)21、改错29 (18)22、改错30 (19)56 改错 (43)57 改错 (44)58 改错 (44)59 改错 (45)60 改错 (46)61 改错 (47)62 改错 (47)63 改错 (48)64 改错 (49)65 改错 (50)66 改错 (50)67 改错 (51)68 改错 (52)69 改错 (52)70 改错 (53)71 改错 (54)72 改错 (54)73 改错 (55)74 改错 (56)75改错 (56)76改错 (57)77改错 (58)78改错 (58)79改错 (59)精品文库81改错 (60)82改错 (61)83改错 (61)84改错 (62)85改错 (63)86改错 (63)87改错 (64)88改错 (65)89改错 (65)90改错 (66)91改错 (67)92改错 (67)93改错 (68)94改错 (68)95改错 (69)96改错 (70)97改错 (71)南开二级C语言上机100题1、改错下列给定程序中,函数fun的功能是:依次取出字符串中所有数字字符,形成新的字符串,并取代原字符串。
请改正程序中的错误,使程序能得出正确的结果。
注意,不要改多main函数,不得增行或删行,也不得更改程序的结构!试题程序#include <stdio.h>#include <conio.h>void fun (char *s){ int i,j;for (i=0,j=0;s[i]!='\0';i++)****************************************if (s[i]>='0' && s[i]<='9')s[j]=s[i]; ——————j改为j++***************************************s[j]="\0"; ——————s[j]='\0'}main(){char item[80];clrscr();printf("\nEnter a string:");gets(item);printf("\n\nThe string is :\%s\n",item);fun (item);printf("\n\nThe string of changing is :\%s\n",item);}2、改错下列给定程序中,函数fun的功能是:分别统计字符串中大写字母和小写字母的个数。
国家计算机等级考试上二级C-改错题
1 下列给定程序中函数fun()的功能是:从低位开始取出长整型变量s中奇数位上的数,依次构成一个新数放在t中。
例如,当s中的数为4576235时,t中的数为4725。
请改正程序中的错误,使它能得到正确结果。
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。
试题程序:#include#include/**********************found***********************/int fun(long s,long *t){long s1=10;*t=s ;while(s>0){/**********************found***********************/s=s 0;*t=s *s1+*t;s1=s1*10;}}main(){long s, t;clrscr();printf("\nPlease enter s: ");scanf("%ld",&s);fun(s,&t);printf("The result is: %ld\n ",t);}答案及评析:(1)错误:int fun(long s,long *t)正确:void fun(long s,long *t)(2)错误:s=s 0;正确:s=s/100;【解析】错误1:函数由指针来完成参数的传递,所以没有返回值,应定义函数的类型为void。
错误2:此处要注意特殊运算符号"%"--取余和"/"--整除的区别。
将一个数整除100则可得到由其百位数以上的数组成的新数字,将一个数整除100取余则可得到由十位数和个位数组成的新数。
2下列给定的程序中,函数fun()的功能是:计算并输出k以内最大的6个能被7或11整除的自然数之和。
K的值由主函数传入,若k的值为500,则函数的值为2925。
国家计算机C语言二级考试改错题库
1 下列给定程序中,函数fun 的功能是:计算S=f(-n)+f(-n+1)+…+f(0)+f(1)+f(2)+…f(n)的值。
例如,当n 为5时,函数值应为10.407143。
f(x)函数定义如下:f(x)=(1)(2)0002(1)(2)0x x x x x x x x ⎧+/->⎪==⎨⎪-/-<⎩或请改正程序中的错误,使它能得出正确的结果。
注意:不要改动main 函数,不得增行或删行,也不得更改程序的结构。
试题程序:#include <stdlib.h> #include <conio.h> #include <stdio.h> #include <math.h>/*************found**************/ f(double x)2 下列给定程序中,fun 函数的功能是:根据形参m,计算下列公式的值:t=1+1/2+1/3+1/4+…+1/m例如,若输入5,则应输出2.283333。
3 下列给定程序中,函数fun 的功能是:分别统计字符串中大写字母和小写字母的个数。
例如,给字符串s 输入:AaaaBBb123CCccccd,则应输出结果:upper=5,lower=9。
4 下列给定程序中函数fun 的功能是:计算正整数num 各位上的数字之积。
例如,若输入252,则输出应该是20。
若输入202,则输出应该是0。
5 下列给定程序中函数fun 的功能是:计算n!。
例如,给n 输入5,则输出120.000000。
6 下列给定的程序中,函数fun 的功能是:计算并输出k 以内最大的10个能被13或17整除的自然数之和。
k 的值由主函数传入,若k 的值为500,则函数的值为4622。
7 下列给定程序中,函数fun()的功能是:根据整型形参m 的值,计算如下公式的值:t=1-1/(22)1/(33)...1/()m m ⨯-⨯--⨯8 在主函数中从键盘输入若干个数放入数组中,用0结束输入并放在最后一个元素中。
@所有人,二级C语言上机考试改错题总结!
@所有人,二级C语言上机考试改错题总结!1、if或while语句若错误行是if或者while语句,则要注意以下点:(1)首先判断是否正确书写if或while关键字;(2)然后看有没有用小括号把整个表达式括起来,若没有则加上小括号;(3)若条件表达式中有指针变量而且没有指针运算符时,则加上指针运算符;(4)若if条件表达式中只有一个等于号即数学等号(=),则要改写成两个等于号即逻辑等号(= =)。
2.for语句若错误行是for语句,则要注意以下几点:(1)首先判断for有没有书写正确;(2)然后看for中的表达式是不是用分号(;)隔开,若不是则改为分号。
记住是分号(;),不是逗号(,)!(3)再者,分析for中的三个表达式,是否符合题意。
3. return语句若错误行为return语句,则要注意以下几点:(1)首先看是不是正确书写return关键字;(2)然后看是不是缺少分号,若是则加上分号即可;(3)再者判断return后的变量或表达式是否正确;这种错误需要根据题意来分析,分析返回变量或表达式的值和类型。
4. 赋值语句若错误行是赋值语句,则要看赋值是否正确,然后看赋值运算符是否写正确。
5. 定义语句若错误行是定义语句,则要注意:(1)首先分析变量类型名是否写对;(2)然后分析给变量赋初值是否正确;(3)若以上均不是,则看是不是少定义了某个变量或少了花括号。
6. 表达式错误问题若错误行中有整数1除以某个表达式或变量时,必须把整数1改为1.0;若变量或表达式是整型时,则只能进行强制类型转换。
7. 字符串类问题若错误行中有字符串结束符,则特别要要注意结束符有没有写错。
但是要区分清楚字符‘o’和数字’0’。
以及字符串结束标记‘\0’。
8. 指针类问题若错误行中有指针变量,并且该变量名之前没有指针运算符,则一般都是加上指针运算符。
9. 函数首部类问题若错误行是函数首部,则要注意:(1)首先看该行最后有没有分号,若有则删掉分号;若中间有分号则要改为逗号;(2)形参和实参类型不一致问题:① 若实参是个地址或数组名或指针变量名,则对应的形参肯定是指针或数组;②若实参是二维数组名,则对应的形参应该是指针数组或是二维数组;③若后面用到某形参的时候有指针运算符,则该形参比为指针类型;④若形参是二维数组或指向M 个元素的指针变量,则该二维的长度必须与main中对于数组的第二维的长度相同。
c语言二级考试题目类型
c语言二级考试题目类型
计算机二级c语言考试题型有单项选择题、程序填空题、程序改错题、程序设计题四大类题型。
各题型分值如下:
一、单项选择题
单项选择题共四十题,四十分,每一个选择分值为1分,其中单项选择中含公共基础知识,该部分十道题,占10分。
二、程序填空题
程序填空题有2-3个空,占比分值18分,该题型为上机题,其三个空占比18分,可想而知其重要性。
三、程序改错题
程序改错题有2-3处错误,该题型分值占比也是18分,难度比程序填空题略难。
该题型也为上机题,也许重视该类题型。
四、程序设计题
程序设计题是计算机二级C语言考试重点,该题为一大题,占比分值24分,该题型也为上机题,为考试重点,需多加练习。
福建省计算机二级考试C语言上机题库改错填空编程
二、改错题Cmody191.c修改程序,用以计算1~100之间所有的偶数之和。
#include <stdio.h>#include <math.h>void main( ){int i=1;/**/ int sum=2 /**/;while(i++,i<=100){ if(/**/ i==(i/2)*2 /**/)continue;sum+=i;}printf("Sum is %d\n",sum);getch();}Cmody192.c修改程序,将二维数组表示的方阵左下半三角(不含对角线)各元素加4,右上半三角(含对角线)各元素乘2。
#include <stdio.h>#define N 5void main(){int a[N][N],i,j;for(i=0;i<N;i++)for(j=0;j<N;j++)a[i][j]=i*5+j+11;printf("\nArray a is:\n");for(i=0;i<N;i++){for(j=0;j<N;j++) printf("%3d ",a[i][j]);printf("\n");}for(i=0;i<N;i++)/**/ for(j=0;j<=i;j++)/**/a[i][j]+=4;for(i=0;i<N;i++)/**/ for(j=i+1 ;j<N;j++) /**/a[i][j]*=2;printf("\nArray a is turned:\n");for(i=0;i<N;i++){for(j=0;j<N;j++)printf("%3d ",a[i][j]);printf("\n");}getch();}Cmody201.c修改程序,计算满足以下条件的整数n的最大值。
全国计算机等级考试2级C语言上机考试例题讲解
2级考试的上机题型有: 级考试的上机题型有: 级考试的上机题型有
1。填空题(30分,2~3个) 。填空题( 分 个 2。改错题(30分,2~3个) 。改错题( 分 个 3。程序编写题(40分,一定记得调试运行,否则没分!) 一定记得调试运行, 。程序编写题( 分 一定记得调试运行 否则没分! 1、 题是按照每个考点的答案给分的, 1、2 题是按照每个考点的答案给分的,也就是说只有和标准 答案一致的才是正确的 。虽然和标准答案不同也有可能运行 正确 ,但是也不能得分 。不过不用担心这个 ,因为题目简单 相应的正确答案的种类也少, 所以运行正确就OK 相应的正确答案的种类也少, 所以运行正确就 ;3题要求 题要求 最高、 最高、 也最灵活 ,只要能写出符合题目要求功能的代码就可 以得40分 以得 分。 出现的问题是: 出现的问题是:有时最后那题就是编不出来 ,前面又错了 就得50分 一点 就得 分……
}
2。删除字符串 。
[例5]:规定输入的字符串中只包含字母和*号。请编写函数 fun,它的功能是:将字符串中的前导*号全部删除,中间和尾部 的*号不删除。例如,若字符串中的内容为 *******A*BC*DEF*G****,删除后,字符串中的内容则应当 是A*BC*DEF*G****。 void fun (char *a) { char *p=a ; while(*p==‘*’) p++; for(; *p!=‘\0’;p++,a++) *a=*p; *a=‘\0’ ; }
练习:fun函数的功能是:在一个字符串中,删除指定 下标的字符,余下的形成一个新串,比如,串a为 “world”,n=3,则输出的字符串为“word”. void fun(char a[], charb[], int n) { int i,k=0 ; for(i=0;a[i]!=‘\0’;i++) {if ( i!=n ) b[k]=a[i]; k++;} b[k]=‘\0 ’;
计算机二级C上机:程序改错题
计算机二级C上机:程序改错题计算机二级C上机:程序改错题为了使广大考生在备战计算机等级考试时,更快的掌握相应知识点,下面是店铺搜索整理的计算机二级C上机:程序改错题,供参考练习,预祝考生们考出自己理想的成绩!程序改错题使用VC++6.0打开考生文件夹下的源程序文件1.cpp,该程序运行时有错,请改正程序中的错误,使程序输出的结果为150200注意:错误的语句在//******error******的下面,修改该语句即可。
提示:定义Numl为一个整型数据位长的`变量。
试题程序:#include//******error******struct{//******error******intNuml:1;intNum2;}MyStruct;voidmain(){MyStructmstr;mstr.Num1=150;mstr.Num2=15;//******error******int*ptr=&mstr.Numl;cout<<*ptr<<endl;*ptr=200;cout<<*ptr<<endl;}答案:(1)“typedefstruct”。
(2)“intNuml:32;”或“intNuml;”。
(3)“int*ptr=(int*)&mstr;”。
【解析】第1处是定义结构体,结构体定义的一般形式为struct(结构体名>{<成员列表>}(变量名列表);程序当中定义结构体名放在后面,MyStruct为结构体变量类型,相当于typedef为已有的类型定义一个新的类型,第1处应改为“typedefstruct”。
第2处是定义Numl为一个整型数据变量,整型数据位数为32(4字节),因此第2处应改成“intNuml:32;”或“intNuml;”。
ptr为整型数据指针,mstr为MyStruct类型结构变量,两者类型不一致应该做强制类型转换,第3处应改成“int*ptr=(int*)&mstr;”,表示将mstr的地址给ptr,ptr指向MyStruct的第一个域Numl,Numl也是整型,类型一致,故可通过ptr指针来改变Numl的值。
二级C上机考试复习资料 填空题和改错题参考答题
二级C上机考试复习资料填空题和改错题参考答题第01套填空题:【1.1.1】x【1.1.2】n【1.1.3】fabs(t)改错题:【1.2.1】for(i=1;i<=y;i++)【1.2.2】t=t%1000;第02套填空题:【2.1.1】n%10【2.1.2】break【2.1.3】break改错题:【2.2.1】if(t==0)【2.2.2】*zero=count;第03套填空题:【3.1.1】0【3.1.2】10*x【3.1.3】n/10改错题:【3.2.1】*t=0;【3.2.2】if(d%2!=0)第04套填空题:【4.1.1】j【4.1.2】0【4.1.3】i++改错题:【4.2.1】for(i=2;i<=m;i++)【4.2.2】y-=1.0/(i*i);第05套填空题:【5.1.1】[M]【5.1.2】N【5.1.3】'\0'改错题:【5.2.1】t=1;【5.2.2】return(2*s);第06套填空题:【6.1.1】[N]【6.1.2】t[i][j]【6.1.3】t[j][i]改错题:【6.2.1】#define FU(m,n)((m)/(n))【6.2.2】return(value);第07套填空题:【7.1.1】k【7.1.2】N【7.1.3】a[k][i]改错题:【7.2.1】for(i=strlen(t)-1;i;i--)【7.2.2】if(t[j]>t[j+1])第08套填空题:【8.1.1】999【8.1.2】t/10【8.1.3】x改错题:【8.2.1】void fun(long s,long*t)【8.2.2】while(s>0)第09套填空题:【9.1.1】sum=0【9.1.2】t[i][i]【9.1.3】1改错题:【9.2.1】double r;【9.2.2】while(fabs(m-n)>0.001)第10套填空题:【10.1.1】char【10.1.2】ch<='9'【10.1.3】'0'改错题:【10.2.1】b[k]=*p;【10.2.2】b[k]='';k++;第11套填空题:【11.1.1】0【11.1.2】i++【11.1.3】2.0*i改错题:【11.2.1】void fun(char*s,char*t)【11.2.2】t[2*d]='\0';第12套填空题:【12.1.1】fp【12.1.2】==【12.1.3】fp改错题:【12.2.1】n=strlen(aa);【12.2.2】ch=aa[i];第13套填空题:【13.1.1】N【13.1.2】substr【13.1.3】0改错题:【13.2.1】int fun(int x,int y,int z)【13.2.2】return j;第14套填空题:【14.1.1】k【14.1.2】N-1【14.1.3】temp改错题:【14.2.1】void fun(int a[][M],int m)【14.2.2】a[j][k]=(k+1)*(j+1);第15套填空题:【15.1.1】a【15.1.2】a【15.1.3】b改错题:【15.2.1】c=c+32;【15.2.2】c=c+5;第16套填空题:【16.1.1】&&【16.1.2】'A'【16.1.3】ch改错题:【16.2.1】void fun(int*a)【16.2.2】a[j]=a[j-1];第17套填空题:【17.1.1】48【17.1.2】s++【17.1.3】sum改错题:【17.2.1】if((k%13==0)||(k%17==0))【17.2.2】}第18套填空题:【18.1.1】1【18.1.2】-1【18.1.3】t改错题:【18.2.1】for(i=1;i<=3;i++)【18.2.2】if(k>=0&&k<=6)第19套填空题:【19.1.1】t,s【19.1.2】s[i]【19.1.3】'\0'改错题:【19.2.1】if(i%k==0)【19.2.2】if(k>=i)第20套填空题:【20.1.1】struct student*【20.1.2】a->score[i]【20.1.3】a改错题:【20.2.1】char*fun(char(*sq)[M])【20.2.2】return sp;第21套填空题:【21.1.1】a[i]【21.1.2】a[j]【21.1.3】a[j]改错题:【21.2.1】switch(g)【21.2.2】case1:return1;case2:return1;第22套填空题:【22.1.1】t[][N]【22.1.2】i=0;i<n【22.1.3】s改错题:【22.2.1】fun(int a[],int m)【22.2.2】else if(m>a[mid])第23套填空题:【23.1.1】*a【23.1.2】2【23.1.3】i+1改错题:【23.2.1】sum=0;【23.2.2】if((i+1)%5==0)第24套填空题:【24.1.1】x【24.1.2】n【24.1.3】t改错题:【24.2.1】d=1;s=0;【24.2.2】d=d/10;第25套填空题:【25.1.1】1.0【25.1.2】1【25.1.3】i改错题:【25.2.1】k=i;【25.2.2】c=k;第26套填空题:【26.1.1】->sno【26.1.2】->name【26.1.3】&t改错题:【26.2.1】double fun(double a,double x0)【26.2.2】if(fabs(x1-x0)>0.00001)第27套填空题:【27.1.1】1【27.1.2】2*i【27.1.3】(-1)改错题:【27.2.1】k++;【27.2.2】if(m==k)第28套填空题:【28.1.1】0【28.1.2】n【28.1.3】(t*t)改错题:【28.2.1】for(i=0;str[i];i++)【28.2.2】if(substr[k+1]==0)第29套填空题:【29.1.1】*s【29.1.2】1【29.1.3】k[n]改错题:【29.2.1】float fun(int k)【29.2.2】return s;第30套填空题:【30.1.1】struct student【30.1.2】n-1【30.1.3】a[i].name,a[j].name 改错题:【30.2.1】q=p+i;【30.2.2】while(q>p)第31套填空题:【31.1.1】a[i]%2【31.1.2】a[j]【31.1.3】j改错题:【31.2.1】fun(int n)【31.2.2】if(n==1)第32套填空题:【32.1.1】10【32.1.2】0【32.1.3】x改错题:【32.2.1】if(n==0)【32.2.2】result*=n--;第33套填空题:【33.1.1】N【33.1.2】k【33.1.3】ss[i]改错题:【33.2.1】int k=0;【33.2.2】while(*p||*q)第34套填空题:【34.1.1】n++【34.1.2】0【34.1.3】s++改错题:【34.2.1】t+=s[k];【34.2.2】*aver=ave;第35套填空题:【35.1.1】s[i]【35.1.2】k【35.1.3】0改错题:【35.2.1】while(*w)【35.2.2】if(*r==*p)第36套填空题:【36.1.1】N【36.1.2】i【36.1.3】-1改错题:【36.2.1】a2=k/10;【36.2.2】return i;第37套填空题:【37.1.1】s【37.1.2】--【37.1.3】return0改错题:【37.2.1】double fun(int n)【37.2.2】c=a;a+=b;b=c;第38套填空题:【38.1.1】3.0【38.1.2】>【38.1.3】(2*i+1)改错题:【38.2.1】double fun(int n)【38.2.2】s=s+(double)a/b;第39套填空题:【39.1.1】n/2【39.1.2】i【39.1.3】a[n-i-1]改错题:【39.2.1】n=*p-'0';【39.2.2】n=n*8+*p-'0';第40套填空题:【40.1.1】a【40.1.2】【40.1.3】score[i]改错题:【40.2.1】s[j++]=s[i];【40.2.2】s[j]=’\0’;第41套填空题:【41.1.1】j=2【41.1.2】i【41.1.3】j改错题:【41.2.1】sum=0;j=0;【41.2.2】if(sum%4==2)第42套填空题:【42.1.1】1【42.1.2】s【42.1.3】i*10改错题:【42.2.1】int fun(int n,int xx[][M])【42.2.2】printf("%d",xx[i][j]);第43套填空题:【43.1.1】struct student【43.1.2】【43.1.3】a.score[i]改错题:【43.2.1】if(p==n)return-1;【43.2.2】a[i]=a[i+1];第44套填空题:【44.1.1】1【44.1.2】i【44.1.3】a[p+i]改错题:【44.2.1】float k;【44.2.2】if(*c>*a)第45套填空题:【45.1.1】1【45.1.2】j++【45.1.3】j改错题:【45.2.1】t=a;a=b;b=t;【45.2.2】return(b);第46套填空题:【46.1.1】0【46.1.2】x【46.1.3】t++改错题:【46.2.1】int i,sl;【46.2.2】t[i]=s[sl-i-1];第47套填空题:【47.1.1】*s【47.1.2】s++【47.1.3】n改错题:【47.2.1】int j,c=0;double xa=0.0;【47.2.2】if(x[j]>=xa)第48套填空题:【48.1.1】i【48.1.2】t++【48.1.3】count改错题:【48.2.1】int fun(int a,int b,int c)【48.2.2】else return1;第49套填空题:【49.1.1】i【49.1.2】ps[j]【49.1.3】tp改错题:【49.2.1】double fun(int n)【49.2.2】return sum;第50套填空题:【50.1.1】a[i]【50.1.2】a[i]【50.1.3】0改错题:【50.2.1】y=1;【50.2.2】d=a-i;。
全国计算机二级C语言上机(2改错题)
全国计算机二级C语言上机(2改错题)1、请编写函数fun,函数的功能是:移动字符串中的内容,移动的规则如下:把第1到第m个字符,平移到字符串的最后,把第m+1到最后的字符移到字符串的前部。
例如,字符串中原有的内容为:ABCDEFGHIJK,m的值为3,则移动后,字符串中的内容应该是:DEFGHIJKABC。
注意:部分源程序在文件PROG1.C中。
请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
#include#include#defineN80voidfun1(char某w)/某本函数的功能是将字符串中字符循环左移一个位置某/{inti;chart;t=w[0];for(i=0;ivoidfun(char某w,intm)/某可调用fun1函数左移字符某/{}main(){chara[N]=\intm;printf(\printf(\fun(a,m);printf(\printf(\NONO();}NONO(){/某请在此函数内打开文件,输入测试数据,调用fun函数,输出数据,关闭文件。
FILE某rf,某wf;chara[N];intm,i;rf=fopen(\wf=fopen(\for(i=0;i<10;i++){ fcanf(rf,\fun(a,m);fprintf(wf,\}fcloe(rf);fcloe(wf);某/}2、学生的记录由学号和成绩组成,N名学生的数据已在主函数中放入结构体数组中,请编写函数fun,它的功能是:把指定分数范围内的学生数据放在b所指的数组中,分数范围内的学生人数由函数值返回。
例如,输入的分数是6069,则应当把分数在60到69的学生数据进行输出,包含60分和69分的学生数据。
主函数中将把60放在low中,把69放在heigh中。
注意:部分源程序在文件PROG1.C文件中。
请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
二级c语言上机改错题题库
/**********found**********/
t=(STU *)calloc(sizeof(STU),m);
else *s += 1;
}
/**********found***********/
s++;}}
10.给定程序MODI1.C中函数fun的功能是:根据整型形参m,计算如下公式的值:
T=1-1/2-1/3-…-1/m
例如,若主函数中输入5,则应输出-0.283333。
{ int sl=0,tl=0; char *ss, *tt;
ss=s; tt=t;
while(*ss)
{ sl++;
/**********found**********/
ss++;
}
while(*tt)
{ tl++;
/**********found***********/
* (p-1) = toupper( *( p - 1 ) ); }
}
else
k = 1;}
17.给定程序MODI1.C中函数fun的功能是:在p所指字符串中找出ASCII码值最大的字符,将其放在第一个位置上,并将该字符前的原字符向后顺序移动。
r=t;
while(*r)
if(*r==*p) { r++; p++; }
else break;
C语言计算机二级改错题
功能:在一个已按升序排列的数组中插入一个数,插入后,数组元素仍按升序排列。
------------------------------------------------------*/#include "stdio.h"#define N 11main(){int i,j,t,number,a[N]={1,2,4,6,8,9,12,15,149,156};printf("please enter an integer to insert in the array:\n");/**********ERROR**********/scanf("%d",&number)printf("The original array:\n");for(i=0;i<N-1;i++)printf("%5d",a[i]);printf("\n");/**********ERROR**********/for(i=N-1;i>=0;i--)if(number<=a[i])/**********ERROR**********/a[i]>=a[i-1];else{a[i+1]=number;/**********ERROR**********/exit;}if(number<a[0]) a[0]=number;printf("The result array:\n");for(i=0;i<N;i++)printf("%5d",a[i]);printf("\n");}1.scanf("%d",&number);2.for(i=N-2;i>=0;i--)for(i=N-2;0<=i;i--)3.a[i+1]=a[i];4.break;功能:用下面的和式求圆周率的近似值。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第5题
给定程序MODI1.C中函数 fun 的功能是:将在字符串s中下标为偶数 位置上的字符,紧随其后重复出现一次,放在一个新串t中,t中字符按原 字符串中字符出现的逆序排列。(注意0为偶数)
main() { char s[100], t[100], u[100]; clrscr(); printf("\nPlease enter string s:"); scanf("%s", s);
printf("\nPlease enter string t:"); scanf("%s", t); fun(s, t, u); printf("the result is: %s\n", u); }
全国计算机等级二级C语言上机改错题题型
第1题 给定程序MODI1.C中函数 fun 的功能是:把在字符串s中出现的每个
字符,紧随其后重复出现一次,形成一个新串放在t中,t中字符按原字 符串中字符顺序排列。
例如:当s中的字符串为:"ABAABBCCDDEE"。
则t中的字符串应为:"AABBCCDDEE"。
void fun (char *s, char *t) { int i, j, sl; sl = strlen(s); /************found************/ for (i=0, j=0; i { t[2*j] = s[i]; t[2*j +1] = s[i]; /************found************/ j--; /参考答案:j++/ } t[2*j] = '\0'; }
请改正函数fun中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!
Modi1.c #include #include #include /************found************/
void fun (char s,char t) /参考答案:void fun (char *s,char *t)/
/************found************/ void fun (char *s, char *t, char u) /参考答案:void fun (char *s, char *t, char *u) { int i, j, sl, tl; sl = strlen(s); tl = strlen(t); for (i=0; i { for (j=0; j if (s[i] == t[j]) break; /************found************/ if (j>tl) /参考答案:if (j>=tl) *u++ = s[i]; } *u = '\0'; }
例如:当s中的字符串为:"ABCDEF"时, 则t中的字符串应为:"EECCAA"。 请改正函数fun中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!
Modi1.c #include #include #include
void fun (char *s, char *t) { int i, j, sl; sl = strlen(s); if(sl%2)sl--; else sl-=2; /************found************/ for (i=sl, j=0; i>=0; i--) /参考答案:for (i=sl, j=0; i>=0; i-=2)/ { t[2*j] = s[i]; t[2*j +1] = s[i]; j++; } /************found************/ t[2*sl] = '\0'; /参考答案:t[2*j] = '\0';/ }
main() { char s[100], t[100]; clrscr(); printf("\nPlease enter string s:"); scanf("%s", s); fun(s, t); printf("The result is: %s\n", t); }
第4题 给定程序MODI1.C中函数 fun 的功能是:将在字符串s中下标为奇数 位置上的字符,紧随其后重复出现一次,放在一个新串t中,t中字符按原 字符串中字符的顺序排列。(注意0为偶数) 例如:当s中的字符串为:"ABCDEF"时, 则t中的字符串应为:"BBDDFF"。 请改正函数fun中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构! Modi1.c #include #include #include
{ int i, sl; sl = strlen(s); for (i=0; i { t[2*i] = s[i]; t[2*i+1] = s[i]; }
/************found************/
t[2*sl] = '0'; /参考答案:t[2*sl] = '\0';/
} main()
main() { char s[100], t[100];
clrscr(); printf("\nPlease enter string s:"); scanf("%s", s); fun(s, t); printf("The result is: %s\n", t); } 第3题 给定程序MODI1.C中函数 fun 的功能是:将在字符串s中下标为偶数 位置上的字符,紧随其后重复出现一次,放在一个新串t中,t中字符按原 字符串中字符的顺序排列。(注意0为偶数) 例如:当s中的字符串为:"ABCDE"时, 则t中的字符串应为:"AACCEE"。 请改正函数fun中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构! Modi1.c #include #include #include void fun (char *s, char *t) { int i, j, sl; sl = strlen(s); /************found************/ for (i=0, j=0; i { t[2*j] = s[i]; t[2*j +1] = s[i]; j++; } /************found************/ t[2*sl] = '\0'; /参考答案:t[2*j]='\0';/ }
void fun (char *s, char *t) { int i, j, sl; sl = strlen(s); /************found************/ if(sl%2) Sl-=2; else Sl--; /参考答案:if(sl%2) sl-=2; else sl--;/ for (i=sl, j=0; i>=0; i-=2) { t[2*j] = s[i]; t[2*j +1] = s[i]; j++; } /************found************/ t[2*sl] = '0'; /参考答案:t[2*j] = '\0';/ }
{ s[100], t[100];
clrscr();
printf("\nPlease enter string s:"); scanf("%s", s);
fun(s, t);
printf("The result is: %s\n", t);
} 第2题 给定程序MODI1.C中函数 fun 的功能是:把在字符串s中出现的每个 字符, 紧随其后重复出现一次,放在一个新串t中,t中字符按原字符串 中逆排列。 例如:当s中的字符串为:"ABCDE"时, 则t中的字符串应为:"EEDDCCBBAA"。 请改正函数fun中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构! Modi1.c #include #include #include void fun (char *s, char *t) { int i, sl; sl = strlen(s); /************found************/ for (i=1; i { t[2*i] = s[sl-i-1]; t[2*i +1] = s[sl-i-1]; } /************found************/ t[2*sl] = '0/'; /参考答案:t[2*sl] = '\0';/ }
void fun (char *s, char *t) { /************found************/ int i, j; /参考答案:int i,j,sl;/ sl = strlen(s); for (i=0, j=0; i { if (i+1 < sl) { t[2*j] = s[i+1]; t[2*j +1] = s[i+1]; j++; } t[2*j] = s[i]; t[2*j +1] = s[i]; /************found************/ j--; /参考答案:j++;/ } t[2*sl] = '\0'; }