1.以下正确的说法是()。
A.用户调用标准库函数前,必须重新定义
B.用户可以重新定义标准库函数,若如此,该函数将失去原有含义
C.系统不允许用户重新定义标准库函数
D.用户调用标准库函数前,不必使用预编译命令将该函数所在文件包括到用户源文件中答案:B
2.do语句能够改写为()语句。
A.复合
B.if
C.switch
D.while
答案:D
3.循环语句“for(inti=0;i<n;i++cout<<i*i<<’’;”中循环体执行的次数为()。
A.1
B.n-1
C.n
D.n+1
答案:C
4.在下面循环语句中循环体执行的次数为()。for(inti=0;i<n;i++if(i>n/2break;
A.n/2
B.n/2+1
C.n/2-1
D.n-1
答案:B
5.下列适宜采用inline定义函数情况是()。
A.函数体含有循环语句
B.函数体含有递归语句
C.函数代码少、频繁调用
D.函数代码多、不常调用
答案:C
6.定义p并使p指向动态空间中的包含30个整数的数组所使用的定义语句为()。
A.int*p=newint[30];
B.int*p=newint(30;
C.int*p=new[30];
D.*p=newint[30];
答案:A
7.将两个字符串连接起来组成一个字符串时,选用()函数。
A.strlen(
B.strcap(
C.strcat(
D.strcmp(
答案:C
8.switch语句能够改写为()语句。
A.for
B.if
C.do
D.while
答案:B
9.关于void指针,下列说法正确的是()。
A.void指针就是不能指向任何数据的指针
B.void指针就是已定义而未初始化的指针
C.指向任何类型数据的指针可直接赋值给一个void指针
D.void指针值可直接赋给一个非void指针
答案:C
10.循环while(inti=0i--;执行次数是()。
A.0
B.1
C.5
D.6
答案:A
11.预处理命令在程序中都是以()符号开头的。
A.*
B.#
C.&
D.@
答案:B
12.以下能正确地定义整型变量a,b和c,并为其赋初值5的语句是()。
A.inta=b=c=5;
B.inta,b,c=5;
C.a=5,b=5,c=5;
D.a=b=c=5;
答案:A
13.若有说明语句:charc='72'则变量c()。
A.包含1个字符
B.包含2个字符
C.包含3个字符
D.说明不合法,c的值不确定
答案:A
14.可用作C++语言用户标识符的一组标识符是()。
A.voiddefine+WORD
B.a3_b3_123YN
C.for-abcCase
D.2aDOsizeof
答案:B
15.以下标识符中不全是保留字的是()。
A.caseforint
B.defathenwhile
C.boolclasslong
D.gotoreturnchar
答案:B
16.下列变量名中,()是合法的。
A.Forest
B.byte-size
C.double
D.A+a
答案:A
17.函数调用func((exp1,exp2,(exp3,exp4,exp5中所含实参的个数为()个。
A.1
B.2
C.4
D.5
答案:B
18.this指针存在的目的是()。
A.保证基类私有成员在子类中可以被访问
B.保证基类保护成员在子类中可以被访问
C.保证每个对象拥有自己的数据成员,但共享处理这些数据成员的代码
D.保证基类公有成员在子类中可以被访问
答案:C
19.定义类的动态对象数组时,系统只能够自动调用该类的()对其进行初始化。
A.友员
B.析构函数
C.无参构造函数
D.类成员
答案:C
20.对两个数组a和b进行如下初始化:chara[]="ABCDEF";charb[]={‘A’,‘B’,‘C’,‘D’
A.a和b数组完全相同
B.a和b中都存放字符串
C.sizeof(a比sizeof(b大
D.sizeof(a与sizeof(b相同
答案:C
21.对长度为N的线性表进行顺序查找,在最坏情况下所需要的比较次数为()。
A.N+1
B.N
C.(N+1/2
D.N/2
答案:B
22.二维数组在内存中的存放顺序是()。
A.按行存放
B.按列存放
C.由用户自己定义
D.由编译器决定
答案:A
23.假如指针p已经指向某个整型变量x,则(*p++相当于()。
A.x++
B.p++
C.*(p++
D.&x++
答案:A
24.如有数组intnum[5]={12,13,14,15,16};则num[0]的值为()。
A.12
B.13
C.14
D.15
答案:A
25.若p1、p2都是指向整型的指针,p1已经指向变量x,要使p2也指向x,正确的是()。
A.p2=p1;
B.p2=**p1;
C.p2=&p1;
D.p2=*p1;
答案:A
26.有语句inta[10]={10,9,8,7,6,5,4,3,2,1},*p=a;则数值为2的表达式是()。
A.a[9]
B.*p[8]
C.*(a+8)
D.p+8
答案:C
27.在C++中,访问一个指针所指向的对象的成员所用的指向运算符是()。
A.*
B.<<
C.->
D.=
答案:C
28.在面向对象的程序设计中,将一组对象的共同特性抽象出来形成()。
A.对象
B.实例
C.类
D.数组
答案:C
29.在用C++进行程序设计时,最好用()代替malloc。
A.new
B.
C.指针
D.循环
答案:A
30.不同对象可以调用相同名称的函数,但执行完全不同行为的现象称为()。
A.继承
B.访问控制
C.派生
D.多态性
答案:D
31.若定义了函数double*function(,则函数function的返回值为()。
A.实数型
B.实数的地址
C.指向函数的指针
D.函数的地址
答案:B
32.所谓数据封装就是将一组数据和与这组数据有关操作组装在一起,形成一个实体,这实体也就
A.类
B.对象
一个星期五的晚上,爸爸在玩电脑,妈妈在看报纸。我写完作业没事干,突发奇想地对爸爸和妈妈说:“咱们全家来玩一个成语接龙比赛吧!”爸妈高兴地说:“好吧。”
妈妈说:“规则是思考一分钟,接不上要罚唱歌!我来打头炮,你们不许交头接耳啊!我的开头是无私无畏。”我暗暗琢磨,这个可不好接呀,看爸爸怎么接这个“畏”字,没想到爸爸竟脱口而出接到:“畏缩不前,”我挠挠后脑勺急忙接道:“前功尽弃,”说完很得意地看着妈妈,看她怎么接这个“弃”字,哈哈。只见妈妈眉头紧皱,默默地念“弃……”妈妈想了一会,也没想出来,正当我得意洋洋的时候,发现爸爸在妈妈的耳边小声说话,“不许交头接耳,违反规则要罚唱歌的。”老爸说:“不要为难***了!”我顺水推舟地说:“那好吧,那你替老妈接!”爸爸眼睛一眯,竟然说出一个“气喘吁吁”我和妈妈同时喊道:“这不算,接错了,该罚老爸唱歌。”
于是,爸爸哈哈一笑说:“好,我认罚。”只见老爸拿起一本书当话筒,学起了赵本山的摸样唱那首《小草》,老爸唱的太可爱了,把我和妈妈逗的笑得前俯后仰。
这个星期五的晚上真有趣,我们一家都很开心。
我们班前不久举行了一场别开生面的成语接龙赛。
比赛规则是:所接词语必须是成语,且不可重复。接龙时成语的最后一个字必须是下一个成语的首字,可以是同音字。如:坐井观天——天长地久。我们以小组为单位,接不上时可向组内求助一次,每次答题时间为五秒。
“一表人才!”只听陈老师一声令下,第一轮比赛开始了。台上的选手们,真可谓是八仙过海,各显神通。只见第一组的选手们有的抓耳挠腮绞尽脑汁,却怎么也想不出来;有的昂首挺胸,嘴角上扬,蹦蹦跳跳,不露一丝惧色;有的紧紧盯着屏幕,恨不得要把它看穿……最搞笑的要数小胡同学了,当他前面一个同学想不出来时,他趁陈老师不注意,身体前倾,双手捂着嘴,凑到他前面一个同学耳边,悄悄地说着什么,脸上还露出一丝得意,估计是想浑水摸鱼,给自己组多“赚”一次求助机会。那个同学答出来了,可他的行为被发现了,求助机会也就用掉了。小胡同学非但没有“赚”到求助机会,还把自己给拌住了。我的心也跟着他揪了起来,他装出满面笑容、胸有成竹的样子,嘴角努力上扬,眼睛眯成了一条线,拼命想掩盖住自己的惊慌,却弄巧成拙,嘴巴都咧到耳朵根了,眉毛也拧成了一个大疙瘩,那半是自信半是惊慌的样子十分好笑。台下的观众们有的捧着肚子哈哈大笑;有的捂着嘴咯咯笑个不停;还有的甚至笑得趴到了桌上,都直不起腰来了。我也忍不住捂着嘴偷偷笑了起来,同时也在心里为他捏了把汗。最终小胡同学还是没答出来,他的队友们愤愤地看着他,即将到手的胜利就这样与他们失之交臂了。
跟小胡同学相比,小周同学算得上是一个幸运儿了,前一个成语是“功作文成名就”。“就,救,就,救……”我和同学们在台下冥思苦想起来。而语文本来就不好的小周同学更是愁眉苦脸,眉毛都成“川”字了。他抓耳挠腮,一脸木讷,连细小的瞳孔也骤然变大。我也紧张极了,脚趾牢牢地抓住地面,连嘴唇也抿得紧紧的'。突然,他一拍脑门,眸子中闪现出智慧的光芒,脸上流露出止不住的兴奋,我的心颤抖起来,心中燃起了希望的火焰。他急切地说道:“救死扶伤,救死扶伤!”听到他说出了答案,我那颗悬着的心才落了下来,仿佛一个蒙山洞,露出了一丝缝隙,照进了一缕阳光。
终于轮到我了,我摩拳擦掌,跃跃欲试,大步迈上了讲台。作为这一组的第一个答题选手,我不免有些紧张,手心里微微冒汗,脚趾也牢牢地抠住地面,同时也很兴奋,十分想为自己争口气。看着陈老师,我默默祈祷:一定要简单点,一定要简单点!“春风化雨!”一听到这个成语,我神经一跳,顿时傻了眼,心怦怦直跳。“雨……鱼?”我想到了“鱼贯而入”,可就在这时,陈老师又补充道:“这个成语的第一个字,只能是‘yǔ’。”这一说,如同给我浇了一盆冷水,我的脑袋里一片空白。这时,我又想到了“与世隔绝”,可又不确定这是不是成语。我越慌想不出来,不知不觉,已经进入倒计时,我见我们组的队友想出来了,就只好选择了求助。
很快,所有人都轮过了一遍,又轮到我了。这次,我清了清嗓子,昂首挺胸,毫不犹豫地说道:“单枪匹马!”这声音压抑得太久了,就像是从岩石缝里钻出来的,特别响亮,后面的同学也特别给力,一个接一个,每个人都能答上来,一股从未有过的喜悦涌上了我的心头。最终,我们组赢得了冠军!
比赛开始了,哥哥望向窗外,目光随着落叶的飘飞渐渐游离,若有所思地说:“枯枝败叶。”
“叶公好龙。怎么样?”我也不甘示弱。
只见哥哥略一沉吟:“龙腾虎跃。”
龙腾虎跃?我不由的抓耳挠腮。平时没有多多积累,此刻只能语塞。“书到用时方恨少啊!”我正想举出白旗,一抬头就看见了哥哥不可一世的.表情。
“跃,跃跃欲试!”我为自己突然冒出的想法感到惊喜。与此同时,我也使哥哥大跌眼镜。看着他惊讶的神色,我暗自得意:看吧,不是年纪小就一定会输哦。
“试——试金石。”他的眉头绞成“川”字,过了好半天,才从牙缝里挤出这几个字。
试金石?呵呵,我就让你试试!“石破天惊!”我脱口而出。
“惊弓之鸟。”
“鸟语花香。”
转眼,比赛进行到了白热化的地步。
此刻,哥哥被我一个“生龙活虎”难倒。
他托着腮,皱着眉头绞尽脑汁。最后,他慢吞吞地说:“我要上WC!”
我倒!无奈之下,我只能眼看着他进了厕所。
半晌,我未见其踪影,心急如焚。最后,我那哥哥终于从WC中踱步而出,“虎啸猿啼!”
啼?原来越战越勇的我一下子无言以对。经过半天的思索,我终于决定——投降了。
正在这时,妈妈走过来,清清嗓子说:“经过本裁判的准确调查,哥哥呢,在厕所翻看了《成语词典》,所以,这场比赛,弟弟获胜!”
话音刚落,我就欢呼雀跃起来。欢呼声久久回荡在夜空中,只有无边的落叶映衬着面红耳赤的哥哥……
古语有云:不依规矩,无以成方圆。无论做什么事情,只有遵守一定的规则,才能获得成功。脚踏实地,是成功的不二法门。
C语言while、do-while、for循环课程5
课程3中,提到C语言基本语句分为:数据定义语句,数据处理语句
数据处理语句又可分为:表达式语句,函数调用语句,空语句(;,复合语句,流程控制语句。
流程控制:指程序代码执行的顺序。流程的分类:顺序、选择、循环。
C语言的循环结构通过三种语句来实现,即while、do-while、forWhile语句的一般形式while(循环条件表达式循环体语句;
功能:当循环条件表达式为真,执行循环体语句,执行完了,再判断条件表达式是否为真,为真,则再执行,直到条件表达式为假时,退出while循环。
实例1:用while语句求1~100的累加和。
#include//C语言编译预处理命令,文件包含为stdio.h
voidmain(//至少有一个用main(命名的主函数,返回值为void无值类型{
inti=1,sum=0;/*初始化循环,定义变量i和累加器sum,定义和之前,累加器清零*/
while(i<=100
{
sum+=i;//sum+=i是一个复合赋值运算符,等价于sun=sun+i;i++;
}
printf("1+2+3+...+100=%d ",sum;//输出十进制数,1加到100累加器的和}
MicrosoftVisualC++6.0运行结果
使用while循环时,一定要对循环条件表达式中出现的变量提前赋值,并在循环体内修改有关变量的值,以使循环能趋于终止。
While循环为当型循环,do-while循环也叫直到型循环。
do-while语句的一般形式为:
do
{
循环体语句}while(
循环条件表达式
实例2:用do-while编制一个求n!的程序,n的值由键盘输入。
#include
voidmain(
{inti=1,n,p=1;
printf("请从键盘输入一个数,进行连乘积: ";
scanf("%d",&n;
do
{p=p*i;
i++;
}while(i<=n;
printf("连乘积的结果为p=n!:%d ",p;
}
分析:此程序,先定义三个变量i、n、p,p从p乘1开始执行,再i进行自增1,循环体中的语句执行完毕后,判断while的循环条件表达式,当i自增1为2时,看2是否<=输入的n值,若为真,则继续返回do循环,直到i自增的值比n大,则退出循环。
do-while主要用于人机交互,do-while循环是先执行后判断,do里面的循环体至少被执行一次。区别于while是先判断循环条件表达式,后执行。
for循环也叫步长型循环
一般格式:for(表达式1;表达式2;表达式3循环体语句;
功能:先执行表达式1,再执行表达式2,如果表达式2的值为真,就执行循环体语句,最后执行表达式3.完成一次循环后,从表达式2执行,直到表达式2为假,退出循环。
实例3:参考实例1,用while求1~100的累加和,现在用for语句求1~100的累
加和。
#include
intmain(void
{
inti;intsum=0;
/*初始化循环,定义变量i
和累加器sum,定义和之前,累加器清零*/
for(i=1;i<=100;i++
{
sum=sum+i;
}
printf("sum=%d ",sum;
return0;
}
实例4:爱因斯坦的`阶梯问题:有一个长阶梯,若每步上2阶,最后剩1阶;若每步上3阶,最后剩2阶;若每步上5阶,最后剩4阶;若每步上6阶,最后剩5阶;只有每步上7阶,最后刚好一阶也不剩。请问该阶梯至少有多少阶。编写一个C程序解决该问题。
#include
main(
{intx;
for(x=7;;x+=7
if(x%3==2&&x%5==4&&x%6==5
break;
printf("Thenumberoftheladdersis:%d ",x;
}
分析:发现x一定是7的整数倍,可以依次递增地求出7的整数倍的值(7*1、7*2、7*3……),每求出一值,就用该值与2、3、5、6进行取模运算,最先得到的满足上述5个方程式的x值即为本题的答案。
用while语句,简单快速实现爱因斯坦的阶梯问题
#include
intmain(
{
inti=1;/*i为所设的阶梯数*/
while(!((i%2==1&&(i%3==2&&(i%5==4&&(i%6==5&&(i%7==0
++i;/*满足一组同余式的判别*/
© 2022 xuexicn.net,All Rights Reserved.