1、|【上机题命题及答题要点】1、 近年来江苏省高校上机题目难度有所下降。本轮上机命题的难度系数与全国计算机等级考试二级 C语言接近。2、 改错题通常有 34 个错误。错误分为两大类,一类是语法出错,这类错误比较查错和容易修改,即在编译时报的错误 。另一类是结果出错,即程序的算法出错,这类错误需认真审题。3、 编程题必须掌握 C 语言的文件,应熟悉文件指针的定义,文件的打开及文件的输入输出。编程题的固定框架。必须记忆。以 C01 的编程为例。#include /*库函数 exit(0)需要*/#include /*定义文件指针时需要的头文件*/.int palindrome(char *str,
2、char *r)void main() FILE *fp;所有数据类型的说明和定义if(fp=fopen(“t:myf2.out“,“w“)=NULL) printf(“nCant open the file!“); exit (0);函数调用(具体问题具体分析) 结果输出printf(“nMy number is:120992340n“); fprintf(fp,“nMy number is:1292340n“);fclose(fp); 4、 必须熟悉常用算法。5、 江苏省高校计算机二级 C 语言上机编程题常考问题:字符串相关问题、素数相关问题、回文数相关问题、矩阵(二维数组)相关问题、特殊
3、数问题(如,合数、真因子或质因子之和、水仙花数、亲密数、完数、数制转换、哥德巴赫猜想等) 。6、掌握文件输出操作标准形式。【2013 年 3 月江苏省等考上机真题解析】函数编程,按【编程要求】1.编写函数 int palindrome(char *str, char *r)。.要点:函数首部完整照抄。参数为指针时,若对指针不熟悉,在函数体内可以按数组编程。|江苏省高等学校非计算机专业学生(C01)计算机基础知识和应用能力等级考试上机试卷二级 C 语言(试卷代号 C01)(本试卷完成时间 70 分钟)一、改错题(16 分)【程序功能】判断一个 NN 方阵(N 为奇数)是否为魔方阵。魔方阵的判定条
4、件是:方阵中每行、每列、主对角线及副对角线上的数据之和均相等。例如,以下方阵中,主对角线的数据是 8、5、2 之和是 15,副对角线上的数据 6、5、4 之和也是15,并且每行、每列数据之和 15,因此该项方阵是魔方阵。8 1 63 5 74 9 2【测试数据与运行结果】屏幕输出: 8 1 63 5 74 9 2The Array x is a magic square.1 2 35 6 49 8 7The Array x isnt a magic square.【含有错误的源程序】以下源程序已保存在 T 盘 myf1.c 文件内,考生可直接打开该文件测试程序。#include #includ
5、e #include #define N 3void fun(int (*a)N) int i,j,m1,m2,row,colum;m1=m2=0;for(i=0; i#include /*该头文件是调用 getch()函数需要的*/#include #define N 3int fun(int (*a)N) /1、函数要求调用有返回值,void fun(int (*a)N)函数类型设置错误 int i,j,m1,m2,row,colum;m1=m2=0;for(i=0; iint data_palindrome(long s) long k=s,h=0;while(k)h=h*10+k%10
6、,k/=10;if(h=s) return 1;return 0;int main() long a;scanf(“%ld“,if(data_palindrome(a) printf(“%ld is palindrome“,a);else printf(“%ld isnt palindrome“,a);【编程题解答:myf2.c 】#include #include /库函数 strlen()需要#include /库函数 isdigit()、strcpy() 需要,书 P386int Judger(char a) /判断字符串 a 是否是回文字符串的通用函数| int n=0,i,j;n=s
7、trlen(a);for(i=0,j=n-1;i#include #include void substitution(char*,char*,char*); int main() char s80=“ aaacdaaaaaaaefaaaghaa“,t2=“aaa“,g=“22“;puts(s);substitution(s,t,g);puts(s);getch();void substitution(char *,char *,char *) ; int i,j,k;char temp80; for(i=0;si=0;i+) for(j=i,k=0;sj=tkj+,k+);if(tk=0)
8、temp=s+j; strcpy(s+i,g);strcat(s,temp);i+=strlen(g)-1; 【要求】1打开 T 盘中 myfl.c 文件或将上述程序录入到 myf1.c 文件中,根据题目要求及程序中语句之间的逻辑关系对程序中的错误进行修改。2 改错时,可以修改语句中的一部分内容,调整语句次序,增加少量的变量说明或编译预处理命令,但|不能增加其它语句,也不能删去整条语句。3 改正后的源程序(文件名 myfl.c)保存在 T 盘的根目录中供阅卷使用,否则不予评分。二、编程题(24 分)【程序功能】在一组数值不全全的整数中查找次大数。【编程要求】1、编写函数 int findsec
9、max(int data, int count)。函数功能:在 data 数组的前 count 个整数中查找次大数。2、编写函数 main()。函数功能:声明一个整型数组 a 并用测试数据初始化,用数组 a 及数组元素个数作实参调用 findsecmax 函数找出次大数,然后将原数组及次大数输出到屏幕及数据文件myf2.out 中。最后将考生本人的准考证号字符串输出到文件 myf2.out 中。【测试数据与运行结果】测试数据:1,9,2,8,3,7,4,6,10,10屏幕输出: 1 9 2 8 37 4 6 10 10Sec_max: 9【要求】1.源程序文件名为 myf2.c,输出结果文件名
10、为 myf2.out。2.数据文件的打开、使用、关闭均用 C 语言标准库中文件操作函数实现。3.源程序文件和运行结果文件均需保存到 T 盘上,供阅卷使用。4.不要复制扩展名为 obj 和 exe 的文件到 T 盘上。【改错题解答:myf1.c 】此题比较简单。按照标准,原程序存在 6 个错误,所以每个错误,若改正,则得 3 分。实际命题教师只认4 个错误:1、2、5、6,此时每题 4 分。#include #include #include void substitution(char*s,char*t,char*g); /1、自定义函数的声明语句出错 void substitution(ch
11、ar*,char*,char*);int main() char s80=“ aaacdaaaaaaaefaaaghaa“,t4=“aaa“,g3=“22“; /2、字符串数组下标填写为大于或等于字符数加 1puts(s);substitution(s,t,g);puts(s);getch(); return 0; /3、主函数有类型定义,在 TC30 编译时必须有返回语句void substitution(char *s,char *t,char *g) /4、自定义函数的函数头出错 void substitution(char*,char*,char*); int i,j,k;|char
12、temp80; for(i=0;si!=0;i+) /5、循环语句终结条件出错:si=0。否则不执行循环语句for(j=i,k=0;sj=tkj+,k+);if(tk=0) strcpy(temp,s+j); /6、字符串赋值用库函数 strcpy:temp=s+j; strcpy(s+i,g);strcat(s,temp);i+=strlen(g)-1; 【编程题解答:myf2.c 】解题思路 :。编程的关键是需要知道库函数所需要的相应的头文件名。此题较简单。#include int findsecmax(int data, int count) int i, j=0,secmax=0,ma
13、x=data0,b10;for(i=1;imax) max=datai;for(i=0;isecmax) secmax=datai;return secmax;void main() FILE *fp;int i,a20=1,9,2,8,3,7,4,6,10,10,count=10,sec_max; if(fp=fopen(“myf2.out“,“w“)=NULL) printf(“nCant open the file!“); exit (0); sec_max=findsecmax(a,count);for(i=0;i#include #includeint prime(int n;) int i;for(i=2;i=(int)sqrt(n);i+)if(n%i=0) return 0;return 1;int series(int a6,int x,int y) int d=30,i=0,n=x,j,f;while(n=2|prime(n) n+; while(ny-5*d) f=1;for(j=0;j6; j+)if(prime(n+j*d)=0) f=0; break; if(f) for(j=0;j6;j+)aij=n+j*d;i+;n+=2;return i;int main()