当前位置:   article > 正文

【牛客网】每天刷题--第十天_牛客网刷题

牛客网刷题

目录

一.以下程序段的输出结果为( )

二.以下叙述中正确的是()

三.下面程序的输出结果是() 

四.下面可以检测运算过程中出现整型溢出的办法有()

五.在32位小端的机器上,如下代码输出是什么: 

六.有以下类定义 

七.请问运行Test 函数会有什么样的结果? 


一.以下程序段的输出结果为( )

  1. for(int i = 4; i > 1; i--)
  2. for(int j = 1; j < i; j++)
  3. putchar('#');

答案:######

解析:             i=4   j=1 #

                        j=2 #

                        j=3 #

                        j=4

                        i=3   j=1 #

                        j=2 #

                        j=3

                        i=2   j=1 #

                        j=2

                        i=1


二.以下叙述中正确的是()

答案:D 

解析:复合语句可以包含多条语句 , 在其中可以定义局部变量 , 所以 A 错误。花括号对 {} 不仅用来表示函数的开头和结尾 , 也可以用于表示复合语句 , 所以 B 错误。 C 语言中的语句必须以分号 ";" 结束 , 所以空语句表示为 ";", 不是空行 , 所以 C 错误。


三.下面程序的输出结果是() 

  1. #include <iostream>
  2. using namespace std;
  3. int i = 0;
  4. int fun(int n) {
  5. static int a = 2;
  6. a++;
  7. return (a * n);
  8. }
  9. int main() {
  10. int k = 5;
  11. {
  12. int i = 2;
  13. k += fun(i);
  14. }
  15. k += fun(i);
  16. cout << k;
  17. return (0);
  18. }

答案:11

这题学习了,原来不知单纯只是 { } 也能组成作用域。

1. 所以上题 { } 内使用的 i 是局部变量 i,i=2,在第一句 k += fun( i ) 后k变成了11;

2. 第二句k += fun( i ) 是在 { } 外,使用的i是全局变量,i=0,所以 k += fun( i ) 后k加上了0等于11; 


四.下面可以检测运算过程中出现整型溢出的办法有()

 答案:B C

解析:

选项1 : 运算结果进行比较的话,已经溢出导致结果变化,去比较也为时已晚。 所以不正确

选项2 : 检测符号为变化可以防止符号溢出,正确。

选项3 : a+b = c   c - a != b 则c溢出 正确

选项4 : 参数长度    0000000000000000000000000 这个长度算溢出么 不正确


五.在32位小端的机器上,如下代码输出是什么: 

  1. char array[12] = {0x01 , 0x02 , 0x03 , 0x04 , 0x05 , 0x06 , 0x07 , 0x08};
  2. short *pshort = (short *)array;
  3. int *pint = (int *)array;
  4. int64 *pint64 = (int64 *)array;
  5. printf("0x%x , 0x%x , 0x%llx , 0x%llx", *pshort , *(pshort+2) , *pint64 , *(pint+2));

 答案:B

解析:

B。

小端机器的数据高位字节放在高地址,低位字节放在低地址。

char array[12] = {0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08};

1,char一字节,直观呈现的结果为:0x08-07-06-05-04-03-02-01(从后到前下标为0-7);

2,short两字节,直观呈现 的结果 为: 0x0807-0605-0403-0201 (从后到前 下标 为0-3) :

*pshort从0开始,所以0x201;

*(pshort+2)从2开始,所以0x605;

3,int64八字节,直观呈现 的结果 为 0x0807060504030201 (从后到前 下标 为0) :

*pint64从0开始,所以0x807060504030201;

4,int四字节,直观呈现为0x08070605-04030201(从后到前 下标 为0-1) :

*(pint+2))从2开始,但是最多只到下标1,后面位置默认为0。


六.有以下类定义 

  1. #include<iostream>
  2. using namespace std;
  3. class Clock{
  4. public:
  5. Clock(int NewH=0, int NewM=0, int NewS=0){Hour=NewH; Minute=NewM;Second=NewS;}
  6. void ShowTime() {cout<<Hour<<":"<<Minute<<":"<<Second;}
  7. Clock operator ++();
  8. private:
  9. int Hour, Minute, Second;};
  10. Clock Clock::operator ++(){
  11. Second++;
  12. if(Second>=60){
  13. Second=Second-60;
  14. Minute++;
  15. if(Minute>=60){
  16. Minute=Minute-60;
  17. Hour++;
  18. Hour=Hour%24;}}
  19. return ________;
  20. }
  21. };
  22. int main() {
  23. Clock c1;
  24. (++c1).ShowTime();
  25. return 0;
  26. }

答案:*this

解析:选B。return *this返回的是当前对象的克隆或者本身,return this返回当前对象的地址,这里很明显是返回当前对象。c1是定义在主函数里面的对象,很明显不对。Clock是类名,也不对。


七.请问运行Test 函数会有什么样的结果? 

  1. char* getmemory(void){
  2. char p[]= " hello world";
  3. return p;
  4. }
  5. void test(void){
  6. char *str=NULL;
  7. str=getmemory(); printf(str);
  8. }

答案:输出乱码

解析:getmemory 返回的指针,是内部变量,  调用之后会被回收。 所以输出是不确定的。 

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号

        
cppcmd=keepalive&