江苏高校计算机等级考试二级C语言上机真题的答题要点Word文档下载推荐.docx

上传人:b****5 文档编号:19457298 上传时间:2023-01-06 格式:DOCX 页数:24 大小:25.61KB
下载 相关 举报
江苏高校计算机等级考试二级C语言上机真题的答题要点Word文档下载推荐.docx_第1页
第1页 / 共24页
江苏高校计算机等级考试二级C语言上机真题的答题要点Word文档下载推荐.docx_第2页
第2页 / 共24页
江苏高校计算机等级考试二级C语言上机真题的答题要点Word文档下载推荐.docx_第3页
第3页 / 共24页
江苏高校计算机等级考试二级C语言上机真题的答题要点Word文档下载推荐.docx_第4页
第4页 / 共24页
江苏高校计算机等级考试二级C语言上机真题的答题要点Word文档下载推荐.docx_第5页
第5页 / 共24页
点击查看更多>>
下载资源
资源描述

江苏高校计算机等级考试二级C语言上机真题的答题要点Word文档下载推荐.docx

《江苏高校计算机等级考试二级C语言上机真题的答题要点Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《江苏高校计算机等级考试二级C语言上机真题的答题要点Word文档下载推荐.docx(24页珍藏版)》请在冰豆网上搜索。

江苏高校计算机等级考试二级C语言上机真题的答题要点Word文档下载推荐.docx

"

);

exit(0);

函数调用(具体问题具体分析)

结果输出

printf("

\nMynumberis:

120992340\n"

fprintf(fp,"

1292340\n"

fclose(fp);

4、必须熟悉常用算法。

5、江苏省高校计算机二级C语言上机编程题常考问题:

字符串相关问题、素数相关问题、回文数相关问题、矩阵(二维数组)相关问题、特殊数问题(如,合数、真因子或质因子之和、水仙花数、亲密数、完数、数制转换、哥德巴赫猜想等)。

6、掌握文件输出操作标准形式。

 

【2013年3月江苏省等考上机真题解析】

江苏省高等学校非计算机专业学生(C01)

计算机基础知识和应用能力等级考试上机试卷

二级C语言(试卷代号C01)

(本试卷完成时间70分钟)

一、改错题(16分)

【程序功能】

判断一个N×

N方阵(N为奇数)是否为魔方阵。

魔方阵的判定条件是:

方阵中每行、每列、主对角线及副对角线上的数据之和均相等。

例如,以下方阵中,主对角线的数据是8、5、2之和是15,副对角线上的数据6、5、4之和也是15,并且每行、每列数据之和15,因此该项方阵是魔方阵。

816

357

492

【测试数据与运行结果】

屏幕输出:

816

TheArrayxisamagicsquare.

123

564

987

TheArrayxisn’tamagicsquare.

【含有错误的源程序】

以下源程序已保存在T盘myf1.c文件内,考生可直接打开该文件测试程序。

conio.h>

#defineN3

voidfun(int(*a)[N])

{inti,j,m1,m2,row,colum;

m1=m2=0;

for(i=0;

i<

N;

i++)

{m1+=a[i][i];

m2+=a[i][N-i-1];

}

if(m1!

=m2)return0;

{row=colum=i;

for(j=0;

j<

j++)

{row+=a[i][j];

colum+=a[j][i];

if((row!

=colum)||(row!

=m1))

return0;

return1;

voidprint(intx[][N])

{inti,j;

{for(j=0;

%3d,x[i][j]"

\n"

intmain()

{intx[N,N]={{8,1,6},{3,5,7},{4,9,2}},y[N,N]={{1,2,3},{5,6,4},{9,8,7}};

print(x);

if(fun(x))printf("

TheArrayxisamagicsquare.\n"

elseprintf("

TheArrayxisn'

tamagicsquare.\n"

print(y);

if(fun(y))printf("

TheArrayyisamagicsquare.\n"

TheArrayyisn'

getch();

【要求】

1.打开T盘中myfl.c文件或将上述程序录入到myf1.c文件中,根据题目要求及程序中语句之间的逻辑关系对程序中的错误进行修改。

2.改错时,可以修改语句中的一部分内容,调整语句次序,增加少量的变量说明或编译预处理命令,但不能增加其它语句,也不能删去整条语句。

3.改正后的源程序(文件名myfl.c)保存在T盘的根目录中供阅卷使用,否则不予评分。

【解析】

/*该头文件是调用getch()函数需要的*/

intfun(int(*a)[N])//1、函数要求调用有返回值,voidfun(int(*a)[N])函数类型设置错误

=colum)&

&

(row!

=m1))//2、逻辑表达式出错:

=m1)

%3d"

x[i][j]);

//3、输出格式出错:

printf("

%3d,x[i][j]"

{intx[N][N]={{8,1,6},{3,5,7},{4,9,2}},y[N][N]={{1,2,3},{5,6,4},{9,8,7}};

//4、数组下标定义出错:

x[N,N]和y{N,N}

二、编程题(24分)

检查一个字符串中中所有数字字符所对应整数(例如,字符'

1'

所对应的整数为1,其他依次类推)之和是否为3的倍数;

判断该字符串是否回文字符串(回文字符串:

正序和倒序相同的字符串。

例如,"

ab121ba"

是回文字符串)。

【编程要求】

1、编写函数intpalindrome(char*str,char*r)。

函数功能:

①检查str指向的字符串中所有数字字符所对应的整数之和是否为3的倍数,若是则将"

yes"

存储到r指向的数组中,否则将"

no"

存储到r指向的数组中.②判断str指向的字符串是否是回文字符串,若是则函数返回1,否则返回0。

2、编写函数main()。

声明字符型数组a和r,输入一个字符串到a数组,用a、r作实寻调用palindrome函数,若字符串中所有数字字符所对应的整数之和是3的倍数且字符串双是回文字符串,则输出该字符串及"

到屏幕及数据文件myf2.out中,否则输出"

到屏幕及数据文件myf2.out中。

最后将考生本人的准考证号字符串输出到文件myf2.out中。

测试数据:

33abbba66

no

12abcba21

yes

1.源程序文件名为myf2.c,输出结果文件名为myf2.out。

2.数据文件的打开、使用、关闭均用C语言标准库中文件操作函数实现。

3.源程序文件和运行结果文件均需保存到T盘上,供阅卷使用。

4.不要复制扩展名为obj和exe的文件到T盘上。

【编程题解题思路】

编程的关键是

①知道库函数所需要的相应的头文件名。

②除主函数和函数palindrome外,根据C语言模块化设计特点,增加了能判断一串字符串是否是回文字符串的自编函数intJudger(chara[]),其中判断回文字符串的函数必须要熟记之,与此同时也要记住判断回文数(data_palindrome)和回文素数的通用函数:

intdata_palindrome(longs)

{longk=s,h=0;

while(k)

h=h*10+k%10,k/=10;

if(h==s)return1;

{longa;

scanf("

%ld"

&

a);

if(data_palindrome(a))printf("

\%ldispalindrome"

a);

\%ldisn'

tpalindrome"

【编程题解答:

myf2.c】

string.h>

//库函数strlen()需要

ctype.h>

//库函数isdigit()、strcpy()需要,书P386

intJudger(chara[])//判断字符串a是否是回文字符串的通用函数

{intn=0,i,j;

n=strlen(a);

for(i=0,j=n-1;

i<

j;

i++,j--)

if(a[i]!

=a[j])return0;

{inti=strlen(str)-1,j=0,m=0;

while(str[i]!

=-1)//计算字符串str中数字字符的数字量值之和

{if(isdigit(str[i]))

m+=(str[i]-48);

i--;

if(m%3==0&

Judger(str))//满足字符串的数字量之和是3的倍数和回文字符串时返回1,并将"

存入数组元素

{strcpy(r,"

j++;

else//不满足字符串的数字量之和是3的倍数和回文字符串时返回0,并将"

j++;

{FILE*fp;

inti;

chara[2][10]={"

33abbba66"

12abcba21"

},r[2][10];

if((fp=fopen("

}

2;

i++)

{if(palindrome(a[i],r[i]))

\n%s\n%s"

a[i],r[i]),fprintf(fp,"

a[i],r[i]);

else

printf("

fclose(fp);

/*操作结束,关闭文件fp*/

蓝色的内容需记忆,并且printf函数与fprintf函数写在一起,用逗号分隔,这样程序不容易

江苏省高等学校非计算机专业学生(C04)

二级C语言(试卷代号C04)

子串查找并替换。

函数substition的功能是在s指向的字符串(简称s串)中查找t指向的子串(简称t串),并用g指向的字符串(简称g串)替换s串中所有的t串。

s:

aaacdaaaaaaaefaaaghaa

t:

aaa

g:

22

22cd2222aef22ghaa

以下源程序已保存在T盘myf1.c文件内,考生可直接打开该文件测试程序。

voidsubstitution(char*,char*,char*);

{chars[80]="

aaacdaaaaaaaefaaaghaa"

t[2]="

aaa"

g[]="

22"

;

puts(s);

substitution(s,t,g);

voidsubstitution(char*,char*,char*);

{inti,j,k;

chartemp[80];

s[i]=='

\0'

i++)

{

for(j=i,k=0;

s[j]==t[k]&

t[k]!

='

j++,k++);

if(t[k]=='

{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盘的根目录中供阅卷使用,否则不予评分。

在一组数值不全全的整数中查找次大数。

1、编写函数intfindsecmax(intdata[],intcount)。

在data数组的前count个整数中查找次大数。

声明一个整型数组a并用测试数据初始化,用数组a及数组元素个数作实参调用findsecmax函数找出次大数,然后将原数组及次大数输出到屏幕及数据文件myf2.out中。

1,9,2,8,3,7,4,6,10,10

19283

7461010

Sec_max:

9

1.源程序文件名为myf2.c,输出结果文件名为myf2.out。

2.数据文件的打开、使用、关闭均用C语言标准库中文件操作函数实现。

3.源程序文件和运行结果文件均需保存到T盘上,供阅卷使用。

4.不要复制扩展名为obj和exe的文件到T盘上。

【改错题解答:

myf1.c】

此题比较简单。

按照标准,原程序存在6个错误,所以每个错误,若改正,则得3分。

实际命题教师只认4个错误:

1、2、5、6,此时每题4分。

voidsubstitution(char*s,char*t,char*g);

//1、自定义函数的声明语句出错voidsubstitution(char*,char*,char*);

t[4]="

g[3]="

//2、字符串数组下标填写为大于或等于字符数加1

//3、主函数有类型定义,在TC30编译时必须有返回语句

voidsubstitution(char*s,char*t,char*g)//4、自定义函数的函数头出错voidsubstitution(char*,char*,char*);

s[i]!

i++)//5、循环语句终结条件出错:

否则不执行循环语句

{strcpy(temp,s+j);

//6、字符串赋值用库函数strcpy:

temp=s+j;

}

解题思路:

编程的关键是需要知道库函数所需要的相应的头文件名。

此题较简单。

intfindsecmax(intdata[],intcount)

{inti,j=0,secmax=0,max=data[0],b[10];

for(i=1;

count;

i++)//查找整数数组的最大值max

if(data[i]>

max)max=data[i];

for(i=0;

i++)//排除最大值后的整数数据放入临时数组b

if(data[i]!

=max)b[j++]=data[i];

i++)//在临时数组b中找最大值,即是次大值

secmax)secmax=data[i];

returnsecmax;

inti,a[20]={1,9,2,8,3,7,4,6,10,10},count=10,sec_max;

myf2.out"

}

sec_max=findsecmax(a,count);

printf((i+1)%5==0?

%4d\n"

:

%4d"

a[i]),fprintf(fp,i%5==0?

a[i]);

\nsec_max:

sec_max),fprintf(fp,"

sec_max);

/*操作结束,关闭文件fp*/

江苏省高等学校非计算机专业学生(C05)

二级C语言(试卷代号C05)

找出找出所有符合条件的数列:

⑴由6个素数组成;

⑵数列中每一项的值在7~360之间;

⑶数列是一个公差为30的等差数列。

简称这样的数列为等差素数数列。

例如,7376797127157就是符合上述条件的一个等差素数数列。

函数series将x~y范围内所有符合上述条件的等差素数数列依次保存到a指向的二维数组中(一行保存一个数列)。

73767127157

107137167197227257

#include<

math.h>

intprime(intn;

{inti;

for(i=2;

=(int)sqrt(n);

if(n%i==0)

intseries(inta[][6],intx,inty)

{intd=30,i=0,n=x,j,f;

while(n==2||prime(n))

n++;

while(n<

y-5*d)

{f=1;

j<

6;

if(prime(n+j*d)==0)

{f=0;

break;

if(f)

j++)

a[i][j]=n+j*d;

i++;

n+=2;

returni;

intmain()

{inta[30][6],i,j,count;

count=series(inta[][6],7,360);

%5d"

a[i][j]);

1.打开T盘中myfl.c文件或将上述程序录入到myf1.c文件中,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 工程科技 > 能源化工

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1