收藏 分销(赏)

浙江省计算机二级上机操作题(新).doc

上传人:仙人****88 文档编号:9460957 上传时间:2025-03-27 格式:DOC 页数:41 大小:241.50KB
下载 相关 举报
浙江省计算机二级上机操作题(新).doc_第1页
第1页 / 共41页
浙江省计算机二级上机操作题(新).doc_第2页
第2页 / 共41页
点击查看更多>>
资源描述
第二部份 C程序设计上机操作题 2 一、数列求和 2 二、最大公约数、最小公倍数 6 三、排序算法 7 四、数组 8 五、求整数n的各位数字及各数字之和 11 六、平面上各点之间的距离 13 七、数制转换 16 八、字符串处理 17 九、最大值与最小值 23 十、斐波那契(Fibonacci)数列 26 十一、水仙花、完数、回文数与亲密数 27 十二、方程求根 29 十三、回文数、因子、质因子、素数 32 十三、其他算法 33 第二部份 C程序设计上机操作题 一、数列求和 1、程序调试题 试题一 该程序功能:输入x和正数eps,计算多项式1-x+x*x/2!-x*x*x/3!+...的和直到末项的绝对值小于eps为止。 #include <stdio.h> #include <math.h> void main() { float x,eps,s=1,t=1,i=1; scanf("%f%f",&x,&eps); do { /***** 1 *****/ t=-t*x/++i; //++i--ài++ s+=t; /***** 2 *****/ } while(fabs(t)<eps); // < --à >= printf("%f\n",s); } 试题二 该程序功能:运行时若输入a、n分别为3、6,则输出下列表达式的值: 3+33+333+3333+33333+333333 #include <stdio.h> void main() { int i,a,n; long t=0; /********* 1 *******/ s=0; //s=0--àlong s=0 scanf("%d%d",&a,&n); for(i=1;i<=n;i++) { /******* 2 ******/ t=t*10+i; //i-à1 s=s+t; } s=s*a; printf("%ld\n",s); } 2、程序填空题 试题一 程序功能:调用函数f计算代数多项式1.1+2.2*x+3.3*x*x+4.4*x*x*x+5.5*x*x*x*x当x=1.7时的值。 #include <stdio.h> float f(float, float*,int); void main( ) { float b[5]={1.1,2.2,3.3,4.4,5.5}; printf(“%f\n”,f(1.7,b,5)); } float f( 1 ) // float f( float x, float a[ ], int n) { float y=a[0],t=1; int i; for(i=1;i<n;i++) {t=t*x; y=y+a[i]*t; } 2 ; // return y } 3、程序设计题 试题一 设计程序:计算多项式a0+a1*sin(x)+a2*sin(x*x)+a3*sin(x*x*x)+……的值,并将其值以格式"%.6f"写入到考生目录中Paper子目录下的新建文件design.dat中。 #include<stdio.h> #include<math.h> void main() { FILE *p; int i; float x=2.345,t=1.0,y=0.0; float a[10]={1.2,-1.4,-4.0,1.1,2.1,-1.1,3.0,-5.3,6.5,-0.9}; //* 考生在这里添加代码 p=fopen(“design.dat”,”w”); y=a[0]; for(i=1;i<10;i++) { t=t*x; y=y+a[i]*sin(t); } fprintf(p,”%.6f”,y); fclose(p); } 试题二 计程序:计算多项式a0-a1*x+a2*x*x/2!-a3*x*x*x/3!+...的值,并将其以格式"%f"写到考生目录中Paper子目录下的新建文件design.dat中。 #include <stdio.h> #include <math.h> void main() { FILE *p; int i; float x=1.279,t,y; float a[10]={1.1,3.2,-2.5,5.67,3.42,-4.5,2.54,5.6,0.97,4.65}; // 考生在这里添加代码 p=fopen(“design.dat”,”w”); t=1; y=a[0]; for(i=1;i<10;i++) {t=-t*x/i; y=y+a[i]*t; } fprintf(p,"%f",y); fclose(p); } 试题三 设计程序:计算表达式1+2!+3!+...+12!的值,并将计算结果以格式"%ld" 写入到考生目录中Paper子目录下的新建文件design.dat中 #include <stdio.h> void main() { FILE *p; long s=1,k=1; int i; //考生在这里添加代码 p=fopen("design.dat","w"); for(i=2;i<=12;i++) {k=i*k; s=s+k; } fprintf(p,"%ld",s); fclose(p); } 试题四 设计程序:计算多项式a0+a1*x+a2*x*x+a3*x*x*x+...的值,并将其值以格式"%f"写到考生目录中Paper子目录下的新建文件design.dat中。 #include <stdio.h> #include <math.h> void main() { FILE *p; int i; float x=1.279,t=1,y=0; float a[10]={1.1,3.2,-2.5,5.67,3.42,-4.5,2.54,5.6,0.97,4.65}; // 考生在这里添加代码 p=fopen("design.dat","w"); for(i=0;i<10;i++) { y=y+t*a[i]; t=t*x; } fprintf(p,"%f",y); fclose(p); } 试题五 设计程序:计算2的平方根、3的平方根、...、10的的平方根之和,要求计算结果具有小数点后10位有效位数,并以格式"%.10f\n"写到考生目录中Paper子目录下的新建文件design.dat中。 #include <stdio.h> #include <math.h> void main() { FILE *p; //考生在这里添加代码 int i; float s=0; p=fopen("design.dat","w"); for(i=2;i<=10;i++) s=s+sqrt(i); fprintf(p,"%.10f",s); fclose(p); } 试题六 设计程序:数列第1项为81,此后各项均为它前1项的正平方根,统计该 数列前30项之和,并以格式"%.3f"写到考生目录中Paper子目录下的新建文件design.dat中。 #include <stdio.h> #include <math.h> void main() { FILE *p; float s=0,a=81,i; //考生在这里添加代码 p=fopen("design.dat","w"); for(i=1;i<=30;i++) {s=s+a; a=sqrt(a); } fprintf(p,"%.3f",s); fclose(p); } 试题七 在数组a的10个数中求平均值v,将大于等于v的数组元素进行求和,并将结果以格式"%.5f"写到考生目录中Paper子目录下的新建文件design.dat中。 #include <stdio.h> void main() { FILE *p; int i; float a[10]={7.23,1.5,5.24,2.1,2.45,6.3,5,3.2,0.7,9.81},sum,v=0; //考生在这里添加代码 p=fopen("design.dat","w"); for(i=0;i<10;i++) v=v+a[i]/10; sum=0; for(i=0;i<10;i++) if(a[i]>=v) sum=sum+a[i]; fprintf(p,"%.5f",sum); fclose(p); } 试题八 设计程序: 利用公式π/4≈1-1/3+1/5-1/7+……公式计算π的近似值,直到某一项的绝对值小于1e-6为止。 (π/4的结果不包含此项)将结果以格式"%.6f"写入到考生目录中Paper子目录下的新建文件design.dat中。 #include <stdio.h> #include <math.h> void main() { FILE *fp; float n=1,t=1,pi=0; int i; //考生在这里添加代码 fp=fopen("design.dat","w"); while(1.0/t>=1e-6) {pi=pi+n*1.0/t; t=t+2; n=-n; } pi=pi*4; fprintf(fp,"%.6f",pi); fclose(fp); } 试题九 计算数列1,-1/3!,1/5!,-1/7!的和至某项的绝对值小于1e-5为止(该项不累加),将结果以格式"%.6f"写入到考生目录中Paper子目录下的新建文件design1.dat中。 #include <stdio.h> #include <math.h> void main() { FILE *p; float s=1,t=1,i=3; // 考生在这里添加代码 p=fopen("d:\\design1.txt","w"); t=-t*(i-1)*i; while(fabs(1/t)>=1e-5) {s+=1/t; i=i+2; t=-t*(i-1)*i; } fprintf(p,"%.6f",s); fclose(p); } 二、最大公约数、最小公倍数 1、程序调试题 试题一 该程序功能:输入m、n(要求输入数均大于0,且m>=n),输出它们的最小公倍数。 #include <stdio.h> void main() { int m,n,k; /******** 1 *********/ while(scanf("%d%d",&m,&n),m<0 && n<0); // m<0 && n<0-à!(m>0&&n>0&&m>=n) for(k=m; k%n!=0;) /******** 2 ********/ k=k+n; //改为:k=k+m printf("%d\n",k); } 2、程序填空题 试题一 该程序功能:输入m、n(要求输入数均大于0),输出它们的最大公约数。 #include <stdio.h> void main() { int m,n,k; while(scanf("%d%d",&m,&n), _______1______ ); //!(n>0&&m>0) for( ____2____; n%k!=0||m%k!=0; k--); //k=m或k=n printf("%d\n",k); } 三、排序算法 1、程序调试题 该程序功能:用选择法对10个整数按升序排序。 #include <stdio.h> #define N 10 void main() { int i,j,min,temp; int a[N]={5,4,3,2,1,9,8,7,6,0}; printf("\nThe array is:\n"); /* 输出数组元素 */ for (i=0;i<N;i++) printf("%5d",a[i]); for (i=0;i<N-1;i++) /* 排序操作 */ { min = i; for (j=i+1; j<N; j++) /****** 1 ******/ if (a[min]<=a[j]) min =j; //<=----à > /****** 2 ******/ temp=a[min]; a[min]=a[j]; a[j]=temp; /* 数据交换 */ } //j--ài printf("\nThe sorted numbers: \n"); /* 输出排序结果 */ for (i=0;i<N;i++) printf("%5d",a[i]); printf("\n"); } 2、程序设计题 该程序功能:用冒泡法对10个整数按升序排序。 #include <stdio.h> #define N 10 void main() { int i,j,min,temp; int a[N]={5,4,3,2,1,9,8,7,6,0}; printf("\nThe array is:\n"); /* 输出数组元素 */ for (i=0;i<N;i++) printf("%5d",a[i]); // for (i=0;i<N;i++) /* 排序操作 */ { for (j=0; j<N-1-i; j++) if (a[j]>a[j+1]) { temp=a[j]; a[j]=a[j+1]; a[j+1]=temp;} /* 数据交换 */ } printf("\nThe sorted numbers: \n"); /* 输出排序结果 */ for (i=0;i<N;i++) printf("%5d",a[i]); printf("\n"); } 四、数组 1、程序填空题 试题一 该程序功能:输入数组x[7],调用函数f,去除数组中的负数,输出结果为:1 3 4 6 #include <stdio.h> void f(int *a,int *m) { int i,j; for(i=0;i<*m;i++) if(a[i]<0) { for(j=i--;j<*m-1;j++) a[j]=a[j+1]; _____1_____; //(*m)-- } } void main() { int i,n=7,x[7]={1,-2,3,4,-5,6,-7}; _______2_______; //f(x,&n) for(i=0;i<n;i++) printf("%5d",x[i]); printf("\n"); } 试题二 该程序功能:函数f将数组循环左移k个元素,数组x[7]调用函数f后的输出结果为:4 5 6 7 1 2 3 #include <stdio.h> void f(int *a,int n,int k) { int i,j,t; for(i=0;i<k;i++) { ___1___; //t=a[0] for( _______2________ ) a[j-1]=a[j]; //j=1;j<n;j++ a[n-1]=t; } } void main() { int i,x[7]={1,2,3,4,5,6,7}; f(x,7,3); for(i=0;i<7;i++) printf("%5d",x[i]); printf("\n"); } 试题三 该程序功能:调用函数f,求二维数组a中全体元素之和。 #include <stdio.h> float f( _______1_______) //float *x[],int m,int n { float y=0; int i,j; for(i=0;i<m;i++) for(j=0;j<n;j++) y=y+*(*(x+i)+j); return y; } void main() { float a[3][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12}},*b[3]; int i; for(i=0;i<3;i++) b[i]=___2___; //*(a+i) printf("%.2f\n",f(b,3,4)); } 试题四 求出数组a中相邻两个元素的和,并将这些和存放在数组a中,按每一行3个元素的形式输出。(例如:b[1]=a[0]+a[1],b[2]=a[1]+a[2]……,b[9]=a[8]+a[9]) #include <stdio.h> void main() { int a[10],b[10],i; printf("\nInput 10 numbers: "); for (i=0; i<10;i++) /* 数组输入 */ scanf("%d", &a[i]); for (i=1; i<10; i++) b[i]=_ a[i-1]+a[i]_; /* 计算b数组中的元素 */ for (i=1; i<10; i++) { printf("%3d",b[i]); if (_i%3==0_) printf("\n"); /* 每行打印3个数据 */ } } 2、程序设计题 试题一 设计程序:将数组a的每1行均除以该行上的主对角元素(第1行同除以a[0][0],第2行同除以a[1][1],...),然后将a数组写入到考生目录中Paper子目录下的新建文件design.dat中新建的文件design.dat中。 #include <stdio.h> void main() { float a[3][3]={{1.3,2.7,3.6},{2,3,4.7},{3,4,1.27}}; FILE *p; /****以下要求考生写的代码****/ float temp; int i,j; p=fopen(“design.dat”,”w”); for(i=0;i<3;i++) {temp=a[i][i]; for(j=0;j<3;j++) a[i][j]=a[i][j]/temp; } for(i=0;i<3;i++) { for(j=0;j<3;j++) fprintf(p,"%5.1f",a[i][j]); fprintf(p,"\n"); } fclose(p); } 试题二 设计程序:将数组a的每1行均除以该行上绝对值最大的元素,然后将a数组写入到考生目录中Paper子目录下的新建文件design.dat中。 #include <stdio.h> #include <math.h> void main() { float a[3][3]={{1.3,2.7,3.6},{2,3,4.7},{3,4,1.27}}; FILE *p; float x; int i,j; //考生在这里添加代码 for(i=0;i<3;i++) { x=a[i][0]; for(j=0;j<3;j++) if(fabs(x)<fabs(a[i][j])) x=a[i][j]; for(j=0;j<3;j++) a[i][j]=a[i][j]/x; } p=fopen("design.dat","w"); for(i=0;i<3;i++) { for(j=0;j<3;j++) fprintf(p,"%10.6f",a[i][j]); fprintf(p,"\n"); } fclose(p); } 试题三 在整数数组a中找出偶数放到数b中,对数组b按从小到大的顺序排序后发格式“%3d”每行3个数写入考生文件夹中paper子文件夹下的新建文件design1.dat。 #include <stdio.h> void main() { FILE *p; int i,j,temp,n=0; int a[10]={7,6,20,3,14,88,53,62,10,29},b[10]; //考生在这里添加代码 p=fopen("design1","w"); for(i=0;i<10;i++) if(a[i]%2==0)b[n++]=a[i]; for(i=0;i<n-1;i++) for(j=0;j< n-1-i;j++) if(b[j]>b[j+1]) {temp=b[j]; b[j]=b[j+1]; b[j+1]=temp; } for(i=1;i<=n;i++) if(i%3==0) fprintf(p,"%3d\n",b[i-1]); else fprintf(p,"%3d",b[i-1]); fclose(p); } 五、求整数n的各位数字及各数字之和 1、程序调试题 试题一 该程序功能:运行时输入整数n,输出n各位数字之和(如n=1308则输出12,n=-3204则输出9)。 #include <stdio.h> #include <math.h> void main() { int n,s=0; scanf("%d",&n); n=fabs(n); /******** 1 *******/ while(n>1) { //n或n>0或n!=0 s=s+n%10; /******** 2 ******/ n=n%10; //%--à/ } printf("%d\n",s); } 2、程序填空题 试题一 该程序功能:求输入的整数各位数字之和,如输入234则输出9,输入-312则输出6。 #include <stdio.h> #include <math.h> void main() { int n,s=0; scanf("%d",&n); ______ 1 ______ //n=fabs(n); while(n!=0) { ______ 2 ______ //s=s+n%10 n=n/10; } printf("%d\n",s); } 试题二 该程序功能:输入1个整数后,输出该数的位数(若输入3214则输出4,输入-23156 则输出5)。 #include <stdio.h> void main() { int n,k=0; scanf("%d",&n); while( _____1_____ ){ //n或n!=0 k++; _____2_____; //n=n/10 } printf("%d\n",k); } 试题三 该程序功能:调用函数f,将1个整数首尾倒置,若程序输入12345,则输出54321; 若程序输入-34567,则输出-76543。 #include <stdio.h> #include <math.h> long f(long n) { long m,y=0; m=fabs(n); while(m!=0) { y=y*10+m%10; ____1____ //m=m/10; } if(n>=0) return y; else _____2_____ // return -y; } void main() { printf("%ld\t",f(12345)); printf("%ld\n",f(-34567)); } 3、程序设计题 试题一 设计程序:选出5000以下符合条件的自然数。条件是:千位数字与百位数字之和等于十位数字与个位数字之和,且千位数字与百位数字之和等于个位数字与千位数字之差的10倍。计算并输出这些四位自然数的个数cnt及这些数字的和sum到考生目录中Paper子目录下的新建文件design.dat中。 #include<stdio.h> void main() { FILE *p; int cnt,sum; /* 考生在这里添加代码 int i,q,b,s,g; cnt=0;sum=0; p=fopen(“design.dat”,”w”); for(i=1000;i<5000;i++) {g=i%10;s=i%100/10;b=i%1000/100;q=i/1000; if(q+b==s+g && q+b==(g-q)*10) {cnt++;sum=sum+q+b+s+g;} } fprintf(p,"%d,%d",cnt,sum); fclose(p); } 六、平面上各点之间的距离 1、程序调试题 试题一 该程序功能:输入n,再输入n个点的平面坐标,然后输出那些距离坐标原点不超过5的点的坐标值。 #include <stdio.h> #include <math.h> #include <stdlib.h> void main() { int i,n; /***** 1 *****/ struct axy { float x,y; } a; //a--à*a scanf("%d",&n); a=(float*) malloc(n*2*sizeof(float)); //a=(struct axy*) malloc(n*2*sizeof(float)); for(i=0;i<n;i++) /***** 2 *****/ scanf("%f%f",a[i].x,a[i].y); // a[i].x--à&a[i].x a[i].y---à&a[i].y for(i=0;i<n;i++) if(sqrt(a[i].x*a[i].x+a[i].y*a[i].y)<=5) printf("%f,%f\n",a[i].x,a[i].y); } 2、程序填空题 试题一 在考生目录下,有Modify.c程序,该程序中“ N ”是根据程序功能需要填充部分,请完成程序填充(注意:不得加行、减行、加句、减句,否则后果自负) 该程序功能:输入n和平面上n个点的坐标,计算各点间距离的总和。 #include <stdio.h> #include <math.h> #define f(x1,y1,x2,y2) sqrt(pow(x2-x1,2)+pow(y2-y1,2)) 1 // #include <stdlib.h>或#include <malloc.h> void main( ) { float *x,*y,s=0; int i,j,n; scanf(“%d”,&n); x=(float*)malloc(sizeof(float)*n*2); y=x+ 2 ; //n; for(i=0;i<n;i++) scanf(“%f%f”,x+i,y+i); for(i=0;i<n;i++) for(j=0;j<n;j++) s+=f(x[i],y[i],x[j],y[j]); printf(“%.2f\n”,s/2); } 3、程序设计题 试题一 设计程序:x[i],y[i]分别表示平面上一个点的坐标,求下列10个点与点(1.0,1.0)的距离的总和,并将结果以格式"%.6f"写入到考生目录中Paper子目录下的新建文件design.dat中。 #include<stdio.h> #include<math.h> void main() { FILE *p; int i; float x[10]={-1.5,2.1,6.3,3.2,-0.7,7.0,5.1,3.2,4.5,7.6}; float y[10]={3.5,7.6,8.1,4.5,6.0,1.1,1.2,2.1,3.3,4.4}; float s=0.0; /****以下要求考生写的代码****/ p=fopen(“design.dat”,”w”); //以写方式打开文件 for(i=0;i<10;i++) s=s+sqrt((x[i]-1)*(x[i]-1)+(y[i]-1)*(y[i]-1)); //求与点(1.0,1.0)的距离之和 fprintf(p,”%.6f”,s); //以%.6f的格式将和写到文件 fclose(p); } 试题二 设计程序:数组元素x[i]、y[i]表示平面上某点坐标,统计所有各点间最短距离,并将其值以格式"%f"写到考生目录中Paper子目录下的新建文件design.dat中。 #include <stdio.h> #include <math.h> #define len(x1,y1,x2,y2) sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2)) void main() { FILE *p; int i,j; float c,minc; float x[]={1.1,3.2,-2.5,5.67,3.42,-4.5,2.54,5.6,0.97,4.65}; float y[]={-6,4.3,4.5,3.67,2.42,2.54,5.6,-0.97,4.65,-3.33}; minc=len(x[0],y[0],x[1],y[1]); /****以下要求考生写的代码****/ p=fopen(“design.dat”,”w”); for(i=0;i<10;i++) for(j=i+1;j<10;j++) {c=len(x[i],y[i],x[j],y[j]); if(c<minc) minc=c; } fprintf(p,”%f”,minc); fclose(p); } 试题三 设计程序:数组元素x[i]、y[i]表示平面上某点坐标,统计10个点中处在圆 (x-1)*(x-1)+(y+0.5)*(y+0.5)=25内的点数k,并将变量k的值 以格式"%d"写到考生目录中Paper子目录下的新建文件design.dat中。 #include <stdio.h> #include <math.h> void main() { FILE *p; int i,k=0; float x[]={1.1,3.2,-2.5,5.67,3.42,-4.5,2.54,5.6,0.97,4.65}; float y[]={-6,4.3,4.5,3.67,2.42,2.54,5.6,-0.97,4.65,-3.33}; //考生在这里添加代码 p=fopen("design.dat","w"); for(i=0;i<10;i++) if((x[i]-1)* (x[i]-1)+ (y[i]-0.5)* (y[i]-0.5)<25) k++; fprintf(p,"%d",k); fclose(p); } 试题四 程序设计题:考生目录下有Design.c程序,请完成以下功能:x[i],y[i]表示点d(i)的平面坐标,求d(0)至d(1)、d(1)至d(2)、……d
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传
相似文档                                   自信AI助手自信AI助手

当前位置:首页 > 教育专区 > 小学其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服