2012全国计算机二级C语言(C++)上机编程题技巧总结和答案 下载本文

二级C语言上机编程题技巧

一、 方法总结

1、 二级C语言上机编程题在二级上机考试中属于较难题型,因此很多同学都害怕通过不了。综合

往年的考试,结合考试大纲,每年考试的编程题都有一定的规律和方法,只要同学们认真熟练使用做题的方法,通过考试是没有问题的。

2、 编程题做题方法一:使用C语言特有的函数做题

(1) 编程思想:使用C语言函数库中的做题,做题时必须注意包含对应的头文件

(2) 考题举例:题库中的第37题,要求将数字字符串转化为对应整数,例如“-1234”转化

后为-1234。做题时需要添加头文件#include \,然后在fun函数中写入程序return atol(p);其中atol(p)表示将p从字符串转化为长整型数。最后编译,运行后输入测试数据后即可得到满分。 #include #include #include \long fun ( char *p) {

return atol(p);

}

(3) 方法总结:该类方法可以适用的题目较少,同学们了解即可。

3、 编程题做题方法二:使用规律做题

(1) 编程思想:部分题目的答案是固定的,不会因为输入的数据改变而改变,因此这部分题目

我们直接将答案记住即可,减少编程的麻烦。

(2) 考题举例:题库中的70题,求cos(x)-x=0的一个实根。做题时候在fun函数中输入return

0.739085;后点击编译和运行即可,无需输入测试数据。(补充:如果需要输入测试数据,程序在输出的黑屏上面会提示,不过一般是英文提示,所以同学们要格外小心) #include #include double fun() {

return 0.739085;

}

(3) 考题总结:该题为每年必考的题目,因此同学们要将答案熟记,以便大家能顺利通过考试。

4、 编程题做题方法三:使用C语言编程

(1) 编程思想:该种方法是考试中使用频率最多的方法,就是使用学习的C语言进行编程,对

C语言的知识进行综合运用,因此难度较大,容易出错。

(2) 考题举例:题库14题,求小于形参n同时能被3和7整除的所有自然数之和的平方根,

并作为函数的返回。做题时时一定要按照三个步骤来:一要定义,二要满足题意,三要看有无返回。

#include

#include

double fun( int n) {

int i;

int sum=0;

for(i=0;i

return sqrt(sum);

}

(3) 考题总结:该题属于编程方法中较简单的题型,做题时也可以使用简便方法,请参考考试

总结中的叙述。

5、 编程题做题方法四:使用简便方法做题

(1) 编程思想:顾名思义这是一种简单而且高效的方法,可是要提醒大家里面的方法不是看一

遍就能掌握的,同学们要仔细再仔细,多练习多思考。

(2) 考题举例:题库第8题,要求除了字符串前导的*号之外,将串中其他的*号全部删除。例

如,字符串的内容:****A*BC*DEF*G*******,删除后为:****ABCDEFG。做题步骤如下:

1) 读题目,否则将不能正确做题。该题目的要求很清晰,就是删除*号,但是不能删

除前导*号。这里大家要知道什么是前导*号?其实它是指字符串中第一个字母以前的全部*号,该题中有4个前导*号。

2) 开始做题,找到NONO函数,了解做题的来龙去脉。以该题为例,以下是NONO函数

的全部内容: NONO()

{ /* 本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。 */

FILE *in, *out ;

int i ; char s[81] ;

in = fopen(\out = fopen(\for(i = 0 ; i < 10 ; i++) {

fscanf(in, \fun(s) ;

fprintf(out, \}

fclose(in) ; fclose(out) ; }

分析NONO函数:分析过程有点多,第一次就要将其看懂,后面就可以很轻松!

① FILE *in, *out;表示定义了两个文件类型的指针in和out,用来指向某个打开的某

个文件。

② int i ; char s[81] ;定义了一个整型的变量i,一般用来表示循环的递增;定义了

一个字符类型的一维数组s,这里数组s没有存储任何的数据,因此一般是闲置用来后面题目中存放数据使用的。

③ in = fopen(\in是上面定义的文件指针,用来

指向一个文件in.dat。首先大家要知道open在英语里面表示是“打开”,file在英语里面是“文件”,因此形象记忆fopen就是打开文件,打开什么文件?看后面的存储目录D:\\\\k01\\\\24010001\\\\in.dat,就是这个路径下面的文件in.dat,以”r”只读的形式打开,记住不能就行对in.dat的改动。

④ out = fopen(\;out文件指针用来指向out.dat,

打开的方式以”w”写的方式写数据,换句话说:in.dat是考试时候的数据源文件,而out.dat是用来存放答案的文件,所以要确保out.dat中的数据完全正确。 ⑤ for(i = 0 ; i < 10 ; i++)循环语句,该循环将执行10次

⑥ fscanf(in, \s) ;从in文件所指向的数据源文件in.dat中读取一行字符串数据

给一维数组s,(顺便说下为什么知道是读取一行字符串数据,是因为%s格式是用来控制字符串的,因此不难判断),通过循环语句,将读取10行数据进行处理,该题目总共40分,因此每行就是4分。 ⑦ fun(s) ;调用函数fun,传入实参s,我们从题目得知fun函数要完成的事情是删除字

符串中的*号,但是不删除前导*号,每次传入的数据都会被执行。

⑧ fprintf(out, \printf在第二章学习的时候知道是输出的意思,fprintf

的意思是将数据输出到out指针指向的文件中,以“%s\\n”格式方式输出,输出的数据是s,同学们一定要注意,此时的s是修改过的s,即是删除*号后的字符串。 ⑨ fclose(in) ;关闭文件指针in

⑩ fclose(out) ;关闭文件指针out,文件打开后要将其关闭。

二、 考题总结

第一种类型:字符串操作一,字符串删除*号

1、 考题库中考题对应编号:8、9、10、19、45、54、57、61、65、71、77、90、92、93、100、

56、60、72、75、85、86

2、 举例:以第10题为例讲解

1) 分析题目:使字符串的前导*号不得多于n个,若多于n个,则删除多余的*好,若少于

或等于n个,则什么也不做,字符串中间和尾部*号不得删除。 2) 分析NONO函数:

NONO()

{/* 本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。 */ FILE *in, *out ;

int i, n ; char s[81] ;

in = fopen(\ out = fopen(\ for(i = 0 ; i < 10 ; i++) {

fscanf(in, \ fscanf(in, \ fun(s,n) ;

fprintf(out, \ }

fclose(in) ; fclose(out) ; }

NONON函数具体分析方法前面(方法四)已经详细讲解过了,现将不同的点进行分析。

fscanf(in, \表示从in.dat中读取一个字符串放到数组s中

fscanf(in, \&n) ;表示从in.dat中读取一个整型数据给变量n,从题目中我们不难发

现s和n之间的关系,就是如果s字符串中的前导多于n个删除,则删除多余的*号,否则什么也不做。

fprintf(out, \只将修改后的字符串输出

3) 在fun函数中输入测试数据,该题函数返回void则无需return语句

#include

void fun( char *a, int n ) {

int test; test=5; }

4) 编译运行,输入一个字符串后还需输入一个n

5) 打开in.dat

分析in.dat中的数据刚好是一行字符串一行整数,总共有20行,通过

fscanf(in, \

fscanf(in, \两个函数每次输入两个数据分别给s和n,例如第一行中输入的时候s字符串就该为:*******A*BC*DEF*G****,n的值就为:4,s字符串中的前导*号为个,多于了n的值,因此需要将多于的3个*号删除。 6) 打开out.dat

打开out.dat并清空数据,因为fprintf(out, \只将修改后的字符串输出,将第一个字符串删除3个*号填写到out.dat中,不输出in.dat中的4

以此类推将数据进行输入:

7) 保存交卷

第二种类型:字符串操作二,移动字符串

1、 考题库中对应试题编号:1、42、83、87 2、 试题举例:以第1题为例

(1) 分析题目:把1到第m个字符平移到字符串的最后 (2) 分析NONO函数:

注意fscanf(rf, \表示从rf指向的文件in.dat中读取两个数据,一个整型数据给变量m,另外一个给数组a。根据题目我们不难判断,程序就完成:将数组a中的字符串从第1个到第m个移动到最后。

(3) 在fun函数中输入测试数据,,该题函数返回void则无需return语句,在执行窗口

中需要输入m的值。

(4) 编译,执行,输入测试数据

(5) 打开in.dat