C语言试题及答案(2)

C语言试题及答案(2),第1张

main()

{ int k, a[10]={1,2,3,4,5}

for(k=1k<3k++) fun(a)

for(k=0k<5k++) printf("%d", a[k])

}

上面程序的输出结果是

A.34756

B.23445

C.35743

D.12345

(40) 请读程序:

#include

#define SUB(X,Y) (X)*Y

main()

{ int a=3, b=4

printf("%d", SUB(a++, b++))

}

上面程序的输出结果是

A.12

B.15

C.16

D.20(41) 请读程序:

#include

main()

{ int mun=0

while(num<=2)

{ num++printf("%d\n",num)}

}

上面程序的输出结果是

A.1

B.1

C.1

D.1

2 2 2

3 3

4

(42) 请读程序:

#include

main()

{ float x,y

scan("%f",&x)

if(x<0.0) y=0.0

else if((x<5.0)&&(x!=2.0))

y=1.0/(x+2.0)

else if (x<10.0) y=1.0/x

else y=10.0

printf("%f\n",y)

}

若运行时从键盘上输入2.0(表示回车),则上面程序的输出结果是

A.0.000000

B.0.250000

C.0.500000

D.1.000000

(43) 请读程序:

#include

main()

{ int x=1, y=0, a=0, b=0

switch(x)

{ case 1:

switch(y)

{ case 0: a++break

case 1: b++break

}

case 2:

a++b++break

}

printf("a=%d, b=%d\n",a,

B.

}

上面程序的输出结果是

A.a=2, b=1

B.a=1, b=1

C.a=1, b=0

D.a=2, b=2

(44) 若有下面的程序片段:

int a[12]={0}, *p[3], **pp, i

for(i=0i<3i++)

p[i]=&a[i*4]

pp=p

则对数组元素的错误引用是

A.pp[0][1]

B.a[10]

C.p[3][1]

D.*(*(p+2)+2)

(45) 请读程序:

#include

#include

main()

{ float x,y,z

scan("%f%f",&x,&y)

z=x/y

while(1)

{ if(fabs(z)>1.0)

{ x=yy=zz=x/y

}

else break

}

printf("%f\n",y)

}

若运行时从键盘上输入3.6 2.4(表示回车),则输出的结果是

A.1.500000

B.1.600000

C.2.000000

D.2.400000

(46) 请读程序:

#include

f(in b[], int n)

{ int i, r

r=1

for(i=0i<=ni++) r=r*b[i]

return r

}

main()

{ int x, a[]={ 2,3,4,5,6,7,8,9}

x=f(a, 3)

printf("%d\n",x)

}

上面程序的输出结果是

A.720

B.120

C.24

D.6

(47) 请读程序:

#include

#include

void fun( char *s)

{ char a[10]

strcpy( a, "STRING")

s=a

}

main()

{ char *p

fun(p)

x=f(a, 3)

printf("%s\n",p)

}

上面程序的输出结果是(└┘表示空格)

A.STRING└┘└┘└┘└┘

B.STRING

C.STRING└┘└┘└┘

D.不确定的值

(48) 若已建立下面的链表结构,指针p、s分别指向图中所示的结点,则不能将s所指的结点插入到链表末尾的语句组是

A.s->next=NULLp=p->nextp->next=s

B.p=p->nexts->next=p->nextp->next=s

C.p=p->nexts->next=pp->next=s

D.p=(*p).next(*s).next=(*p).next(*p).next=s

(49) 请读程序:

#include

void fun(float *pl, float *p2, float *s)

{ s=( float * )calloc( 1, sizeof(float))

*s=*p1+ *(p2++)

}

main()

{ float a[2]={1.1, 2.2}, b[2]={10.0, 20.0}, *s=a

fun(a, b, s)

printf("%f\n",*s)

}

上面程序的输出结果是

A.11.100000

B.12.100000

C.21.100000

D.1.100000

(50) 请读程序:

#include

#include

void fun( char *w, int m)

{ char s, *p1, *p2

p1=wp2=w+m-1

while (p1{ s=*p1++*p1=*p2--*p2=s}

}

main()

{ char a[]="ABCDEFG"

fun( a, strlen(a))

puts(a)

}

上面程序的输出结果是

A.GFEDCBA

B.AGADAGA

C.AGAAGAG

D.GAGGAGA

二、填空题(每空2分,共40分)

请将每空的正确答案写在答题卡上【1】-【20】序号后的横线上,答在试卷上不得分。

(1) DOS命令分为内部命令与外部命令,XCOPY命令是 【1】 命令

(2) 为了列出当前盘当前目录中所有第三个字符为C的文件名的有关信息,应该用命令 【2】 。

(3) 设当前盘为A盘,当前目录为\X\Y,A盘上的一个文件QR.C在当前目录下的子目录W中。现已将A盘的当前目录改为\D\XY,当前盘改为C盘,如需指定A盘上该文件应写成 【3】 。

(4) 用十六进制给存储器中的字节地址进行编号,其地址编号是从0000到FFFF,则该存储器的容量是【4】KB。

(5) 设有两个八位二进制数00010101与01000111相加,其结果的十进制表示为 【5】 。

(6) 数学式子 写成C语言表达式是 【6】 。

(7) 下面程序的输出结果是 【7】 。

#include

main()

{ static char b[]="Goodbye"

char *chp=&b[7]

while( --chp >=&b[0]) putchar( *chp)

putchar(’\n’)

}

(8) 下面程序的输出结果是 【8】 。

#include

void as( int x, int y, int *cp, int *dp)

{ *cp=x+y

*dp=x-y

}

main()

{ int a=4, b=3, c, d

as( a, b, &c, &d)

printf( ’%d %d\n", c, d)

}

(9) 请读程序:

#include

main( int argc, char *argv[])

{ int i

printf( ’%d\n", argc)

for( i=0i<=argc+1i++) printf( "%s ", argv[i])

printf("\n")

}

若上面的程序编译、连接后生成可执行文件ABC.EXE,则输入以下命令行

abc file1 file2(表示回车)

程序执行后的输出结果是 【9】 。

(10) 条件“20(11) 设二进制数a是00101101,若想通过异或运算a^b使a的高4位取反,低4位不变,则二进制数b应是 【11】 。

(12) 若有以下说明和定义语句,则变量w在内存中所占的字节数是 【12】 。

union aa

{ float x, y

char c[6]

}

struct st { union aa vfloat w[5]double ave} w

(13) 下面程序的输出结果是 【13】 。

#include

#define N 5

fun( char *s, char a, int n)

{ int j

*s=aj=n

while( ereturn j

}

main()

{ char s[N+1]

int k, p

for( k=1k<=Nk++)

s[k]=’A’+k+1

printf( "%d\n", fun(s, ’E’, N))

}(14) 下面程序的输出结果是 【14】 。

#include

void fun( char *a1, char *a2, int n)

{ int k

for( k=0ka2[k]=( a1[k]-’A’-3+26)&+’A’

a2[n]=’\0’

}

main()

{ char s1[5]="ABCD", s2[5]

fun( s1, s2, 4)

puts( s2)

}

(15) 下面的findmax函数返回数组s中最大元素的下标,数组中元素的个数由t传入,请填空。

findmax( int s[], int t)

{ int k, p

for( p=0, k=ppif( s[p]>s[k]) 【15】 。

return k

}

(16) 下面程序的输出结果是 【16】 。

#include

fun( int x)

{ int p

if( x==0||x==1) return(3)

p=x-fun( x-2)

return p

}

main()

{ printf( "%d\n", fun(9))}

(17) 下面程序的输出结果是 【17】 。

#include

funa( int a, int b)

{ return a+b}

funb( int a, int b)

{ return a-b}

sub( int (*t)(), int x, int y)

{ return((*t)( x,y))}

main()

{ int x, (*p)()

p=funa

x=sub(p,9,3)

x+=sub(funb, 8, 3)

printf("%d\n", x)

}

(18) 下面程序的输出结果是 【18】 。

#include

main()

{ char *p[]={ "BOOL", "OPK", "H", "SP"}

int i

for(i=3i>=0i--,i--) printf( "%c", *p[i])

printf("\n")

}

(19) 为了建立如图所示的存储结构(即每个结点含两个域,data是数据域,next是向结点的指针域),请填空。

data next

struct link { char data【19】 } node

(20) 下面的程序用来统计文件中字符的个数,请填空。

#include

main()

{ FILE *fp

long num=0

if(( fp=fopen("fname.dat","r"))==NULL)

{ printf( "Can’t open file! \n")exit(0)}

while 【20】

{ fgetc(fp)num++}

printf("num=%d\n", num)

fclose(fp)

}

参考答案

一`选择题((1)~(40)题每题1分,(41)~(50)题每题2分,共60分)

(1)C (2)A (3)B (4)D (5)D (6)A (7)C (8)B (9)D (10)C

(11)B (12)D (13)A (14)C (15)B (16)A (17)B (18)A (19)C (20)C

(21)D (22)B (23)B (24)A (25)C (26)D (27)D (28)B (29)C (30)A

(31)B (32)B (33)D (34)C (35)A (36)C (37)A (38)B (39)C (40)A

(41)C (42)C (43)A (44)C (45)B (46)B (47)D (48)C (49)D (50)C

二` 填空题(每空2分,共40分)

(第(2)`(3)空允许小写或大小写混合使用,其它空均须与答案一样)

(1) 外部

(2) DIR ?? C*.*

(3) A:\X\Y\W\QR.C

(4) 64

(5) 92

(6) pow(sin(x),2) * (a+b)/(a-b) 或 sit(x) * sit(x) * (a+b)/(a-b)

(7) eybdooG

(8) 7 1

(9) 3 abc.exe file1 file2 (注:两个答案,每个1分)

(10) ((20 (11) 11110000

(12) 34

(13) 3

(14) XYZA

(15) k=p

(16) 7

(17) 17

(18) SO

(19) struct link *next

(20) (!feof(fp))或(feof(fp)==0)

因为"=="是判断等号两边的值是否相等的语句。

c语言中的“=”是赋值,“==”才是判断。

等号左边是x,它的值为3,右边是y+z,因为"+"的运算优先级大于"=="所以先执行y+z,得到表达式的值为1+0=1.

所以if(x==y+z)等价于判断 if(3==1),"3==1"的返回值自然是false

于是不执行if()语句下的语句,而是执行else中的printf("+++")

所以最后的输出是 +++

啊,是五道题啊...不是第五题...

没看清楚,不好意思。

等下补答

1. 前缀"--"和后缀"--"的区别:前缀返回的是值改变之后的值,后缀返回的是改变之前的值。

所以输出的一个是后缀的10,一个是前缀的9.

当然如果你再printf("%d,%d",x,y)就都输出9了。

2. 因为x,y,z都是整型变量,所以x/y的返回值是整除的值,也就是商。

10/3=3余1,而%相当于mod,也就是10对3取模。取模运算只能对整数进行。

在两个数都是正整数的时候就等于除法的余数,也就是1。

z=(x/y)是赋值语句返回的值就是改变后的z。

3. 可以看到,它printf的是两个表达式的值。而且是两个逻辑表达式。

第一个是(a+b>c &&b==c) “&&”表示且,也就是当两个都为真的时候返回true,任意一个为假,返回false,可以看到a+b>c是true,而b==c是false,所以返回值是false,因为是以整数形式输出,那么就是true=1,false=0.

第二个式子是c>b>a,c语言中没有连比,这个式子会从左算到右。即(c>b)>a。

其中c>b是true,因为要和a这个整型变量比,所以会强制转int变成1,然后1>a返回值就是false了。

4. 也是前置和后置的问题。m=++i 返回的是i=i+1之后的值。也就是6,n=j--返回的是变化之前的值就是12.

PROCESS BEFORE OUTPUT.

MODULE STATUS_0500.

*

PROCESS AFTER INPUT.

MODULE USER_COMMAND_0500.

*&---------------------------------------------------------------------*

*&Report Z_TEST12

*&

*&---------------------------------------------------------------------*

*&

*&

*&---------------------------------------------------------------------*

REPORT Z_TEST12.

*功能码返回值

DATA:OK_CODE TYPE SY-UCOMM,

SAVE_OK LIKE OK_CODE.

*定制对象

DATA:WA_CONTAINER TYPE SCRFNAME VALUE 'TREE1',

WA_CUSTOM_CONTAINER TYPE REF TO

CL_GUI_CUSTOM_CONTAINER,

WA_TREE TYPE REF TO CL_GUI_SIMPLE_TREE.

*NODE节点

DATA:NODE_TABLE LIKE TABLE OF MTREESNODE,

*节点

NODE1 TYPE MTREESNODE.

*定义内表,变量需要传递,不加HEADER LINE

DATA:WA_SPFLI TYPE TABLE OF SPFLI."WITH HEADER LINE

*当双击时取得节点的KEY值与节点文本值变量

DATA:NODEKEY(200) VALUE 'NONE',NODETEXT(200) VALUE 'NONE'.

*定义对象,定义对象的双击方法,用于将该对象双击方法分*

*配到树双击事件

CLASS LCL_APPLICATION DEFINITION DEFERRED.

*----------------------------------------------------------------------*

* CLASS LCL_APPLICATION DEFINITION

*----------------------------------------------------------------------*

*

*----------------------------------------------------------------------*

CLASS LCL_APPLICATION DEFINITION.

PUBLIC SECTION.

*自定义双击方法,参数为节点关键字

METHODS HANDLE_NODE_DOUBLE_CLICK

FOR EVENT NODE_DOUBLE_CLICK

OF CL_GUI_SIMPLE_TREE

IMPORTING NODE_KEY.

ENDCLASS."LCL_APPLICATION DEFINITION

*&---------------------------------*

*对象方法实现

*&---------------------------------*

CLASS LCL_APPLICATION IMPLEMENTATION.

METHOD HANDLE_NODE_DOUBLE_CLICK.

*MESSAGE I208(00) WITH ’double’.

*取得KEY值,在窗口显示

NODEKEY = NODE_KEY.

*从节点内表中按关键字读取单个节点

READ TABLE NODE_TABLE

WITH KEY NODE_KEY = NODE_KEY

INTO NODE1.

*将节点文本在窗口显示

NODETEXT = NODE1-TEXT.

ENDMETHOD."HANDLE_NODE_DOUBLE_CLICK

ENDCLASS."LCL_APPLICATION IMPLEMENTATION

*定义自定义实例

DATA:G_APPLICATION TYPE REF TO LCL_APPLICATION.

START-OF-SELECTION.

*创建自定义对象

CREATE OBJECT G_APPLICATION.

*直接调用窗口,在窗口PBO分配双击对象

call SCREEN 0500.

*----------------------------------------------------------------------*

* MODULE USER_COMMAND_0500 INPUT

*----------------------------------------------------------------------*

*

*----------------------------------------------------------------------*

MODULE USER_COMMAND_0500 INPUT.

SAVE_OK = OK_CODE.

CLEAR OK_CODE.

CASE SAVE_OK.

WHEN 'EXIT'.

LEAVE PROGRAM.

WHEN 'BACK'.

LEAVE TO SCREEN 0.

ENDCASE.

ENDMODULE."USER_COMMAND_0500 INPUT

*----------------------------------------------------------------------*

* MODULE STATUS_0500 OUTPUT

*----------------------------------------------------------------------*

*

*----------------------------------------------------------------------*

MODULE STATUS_0500 OUTPUT.

SET PF-STATUS '500'.

IF WA_CUSTOM_CONTAINER IS INITIAL.

PERFORM CREATE_TREE.

ENDIF.

ENDMODULE."STATUS_0500 OUTPUT

*&--------------------------------*

*& 创建树及子节点

*&--------------------------------*

FORM CREATE_TREE.

*事件内表及单个事件对象

DATA:EVENTS TYPE CNTL_SIMPLE_EVENTS,

EVENT1 TYPE CNTL_SIMPLE_EVENT.

*建立定制对象

CREATE OBJECT WA_CUSTOM_CONTAINER

EXPORTING

CONTAINER_NAME = WA_CONTAINER.

*建立树对象

CREATE OBJECT WA_TREE

EXPORTING

*LIFETIME =

PARENT = WA_CUSTOM_CONTAINER

*SHELLSTYLE =

NODE_SELECTION_MODE = CL_GUI_SIMPLE_TREE=>NODE_SEL_MODE_SINGLE .

*HIDE_selectION =

*NAME=

*EXCEPTIONS

*LIFETIME_ERROR = 1

*CNTL_SYSTEM_ERROR = 2

*CREATE_ERROR = 3

*FAILED = 4

*ILLEGAL_NODE_selectION_MODE = 5

*OTHERS = 6.

IF SY-SUBRC <>0 .

*MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO

*WITH SY-MSGGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.

ENDIF.

*开始建立树结构

CLEAR NODE1.

*节点关键字

NODE1-NODE_KEY = '国家'.

*第一层

CLEAR NODE1-RELATKEY.

CLEAR NODE1-RELATSHIP.

NODE1-HIDDEN = ''.

NODE1-DISABLED = ''.

NODE1-ISFOLDER = 'X'.

*不带ICON

CLEAR NODE1-N_IMAGE.

CLEAR NODE1-EXP_IMAGE.

CLEAR NODE1-EXPANDER.

*节点文本

NODE1-TEXT = '中国'.

*添加到节点表

APPEND NODE1 TO NODE_TABLE.

*二层节点

CLEAR NODE1.

NODE1-NODE_KEY = '成都'.

*上层关系

NODE1-RELATKEY = '国家'.

NODE1-RELATSHIP = CL_GUI_SIMPLE_TREE=>RELAT_LAST_CHILD

.

NODE1-HIDDEN = ''.

NODE1-DISABLED = ''.

NODE1-ISFOLDER = 'X'.

CLEAR NODE1-N_IMAGE.

CLEAR NODE1-N_IMAGE.

CLEAR NODE1-EXP_IMAGE.

CLEAR NODE1-EXPANDER.

NODE1-TEXT = '成都'.

APPEND NODE1 TO NODE_TABLE.

CLEAR NODE1.

NODE1-NODE_KEY = '深圳'.

*上层关系

NODE1-RELATKEY = '国家'.

NODE1-RELATSHIP = CL_GUI_SIMPLE_TREE=>RELAT_LAST_CHILD

.

NODE1-HIDDEN = ''.

NODE1-DISABLED = ''.

NODE1-ISFOLDER = 'X'.

CLEAR NODE1-N_IMAGE.

CLEAR NODE1-N_IMAGE.

CLEAR NODE1-EXP_IMAGE.

CLEAR NODE1-EXPANDER.

NODE1-TEXT = '深圳'.

APPEND NODE1 TO NODE_TABLE.

CLEAR NODE1.

NODE1-NODE_KEY = '武侯区'.

*上层关系

NODE1-RELATKEY = '成都'.

NODE1-RELATSHIP = CL_GUI_SIMPLE_TREE=>RELAT_LAST_CHILD

.

NODE1-HIDDEN = ''.

NODE1-DISABLED = ''.

NODE1-ISFOLDER = ''.

CLEAR NODE1-N_IMAGE.

CLEAR NODE1-EXP_IMAGE.

CLEAR NODE1-EXPANDER.

NODE1-TEXT = '武侯区'.

APPEND NODE1 TO NODE_TABLE.

CLEAR NODE1.

NODE1-NODE_KEY = '金牛区'.

*上层关系

NODE1-RELATKEY = '成都'.

NODE1-RELATSHIP = CL_GUI_SIMPLE_TREE=>RELAT_LAST_CHILD

.

NODE1-HIDDEN = ''.

NODE1-DISABLED = ''.

NODE1-ISFOLDER = ''.

CLEAR NODE1-N_IMAGE.

CLEAR NODE1-N_IMAGE.

CLEAR NODE1-EXP_IMAGE.

CLEAR NODE1-EXPANDER.

NODE1-TEXT = '金牛区'.

APPEND NODE1 TO NODE_TABLE.

CLEAR NODE1.

NODE1-NODE_KEY = '福田区'.

*上层关系

NODE1-RELATKEY = '深圳'.

NODE1-RELATSHIP = CL_GUI_SIMPLE_TREE=>RELAT_LAST_CHILD

.

NODE1-HIDDEN = ''.

NODE1-DISABLED = ''.

NODE1-ISFOLDER = ''.

CLEAR NODE1-N_IMAGE.

CLEAR NODE1-N_IMAGE.

CLEAR NODE1-EXP_IMAGE.

CLEAR NODE1-EXPANDER.

NODE1-TEXT = '福田区'.

APPEND NODE1 TO NODE_TABLE.

CLEAR NODE1.

NODE1-NODE_KEY = '南山区'.

*上层关系

NODE1-RELATKEY = '深圳'.

NODE1-RELATSHIP = CL_GUI_SIMPLE_TREE=>RELAT_LAST_CHILD

.

NODE1-HIDDEN = ''.

NODE1-DISABLED = ''.

NODE1-ISFOLDER = ''.

CLEAR NODE1-N_IMAGE.

CLEAR NODE1-N_IMAGE.

CLEAR NODE1-EXP_IMAGE.

CLEAR NODE1-EXPANDER.

NODE1-TEXT = '南山区'.

APPEND NODE1 TO NODE_TABLE.

*按照节点内表添加节点

CALL METHOD WA_TREE->ADD_NODES

EXPORTING

TABLE_STRUCTURE_NAME = 'MTREESNODE'

NODE_TABLE = NODE_TABLE.

*EXCEPTIONS

*ERROR)IN_NODE_TABLE = 1

*FAILED = 2

*DP_ERROR = 3

*TABLE_STRUCTURE_NAME_NOT_FOUND = 4

*OTHERS = 5.

IF SY-SUBRC <>0.

*MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO

*WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.

ENDIF.

*定义双击事件

EVENT1-EVENTID =

CL_GUI_SIMPLE_TREE=>EVENTID_NODE_DOUBLE_CLICK.

EVENT1-APPL_EVENT = 'X'.

APPEND EVENT1 TO EVENTS.

*添加事件内表

CALL METHOD WA_TREE->SET_REGISTERED_EVENTS

EXPORTING

EVENTS = EVENTS.

* EXCEPTIONS

* CNTL_ERROR = 1

* CNTL_SYSTEM_ERROR = 2

* ILLEAGL_EVENT_COMBINATION = 3

* OTHERS = 4

IF SY-SUBRC <>0.

*MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO

* WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.

ENDIF.

*将已定义的双击事件分配到树对象

SET HANDLER G_APPLICATION->HANDLE_NODE_DOUBLE_CLICK

FOR WA_TREE.

ENDFORM. "create_tree


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11853734.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-19
下一篇 2023-05-19

发表评论

登录后才能评论

评论列表(0条)

保存