C语言—每日选择题—Day56

发布时间:2023年12月21日

?指针相关博客

打响指针的第一枪:指针家族-CSDN博客

深入理解:指针变量的解引用 与 加法运算-CSDN博客

第一题

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

A:'\0' 表示字符 0

B:"a" 表示一个字符常量

C:表达式:'a' > 'b' 的结果是 假;

D:'\"' 是非法的

答案及解析 C

本题考查的是基础

A:字符' \0 '的ASCII是0,而字符 ' 0 '的ASCII值为48,所以他们不一样;

B:"a"这是一个字符串,后面有个隐藏的\0,要注意是双引号!

C:正确,看ASCII值就知道了

D:' \" ',这个是一个转义字符,\把后面的"原本表达的意思改变了,所以\"是一个新字符,正确用法。

第二题

2. 已知 int a[] = { 0,2,4,6,8,10 }, *p = a+1;其值等于0的表达式是( )

A:* (p++)

B:*(++p)

C:*(p--)

D:*(--p)

答案及解析 D

做了这么久的朋友,这个题应该没什么问题吧!

首先p指向的是a数组第二个元素的地址,而要值等于0,就要通过p拿到数组首元素的地址。

所以必须让p缩小,排除AB;

C D的区别就是前置--和后置--,前置--的表达式的值为--之后的值;后置--为--之前的值;

所以D:--p,就是数组首元素地址;*(--p) = *a = 0;

第三题

3. 在c语言中,下面能正确进行字符串赋值操作的是()

A:char s[5]={"ABCDE"};

B:char s[5]={‘A’,‘B’,’C’,’D’,’E’};

C:char *s; s="ABCDE";

D:char *s; scanf("%s",s);

答案及解析?C

C语言中,字符串必须是以’\0'结尾,所以给字符串赋值必须赋值\0;

A:s定义为5个元素的字符型数组,即最多能存放5个字符,字符串结尾符’\0’无法存放;

B:对数组赋值没错,但同A一样,没有字符串结尾符’\0’;

D:“野指针”赋值,是错误的:

C:先定义字符指针s,而后将字符串"ABCDE”的首地址赋值给指针变量s,s指向这个字符串

第四题

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

#include <stdio.h>
int main() 
{
    int a[5] = {1, 2, 3, 4, 5};
    int *ptr=(int *)(&a + 1);
    printf("%d, %d",*(a + 1), *(ptr - 1 ));
    return 0;
}

A:2, 5

B:1, 3

C:1, 5

D:2, 43586

答案及解析 A

这个题我记得是出现了3次,非常经典!

我建议大家可以看一下我的这个博客,没做对的自己再去做一遍,还是不行评论区发出来

深入理解:指针变量的解引用 与 加法运算-CSDN博客

第五题

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

#include <stdio.h> 
int main() 
{
    char str1[] = "hello world";  
    char str2[] = "hello world";  
 
    const char str3[] = "hello world";  
    const char str4[] = "hello world";  
 
    const char* pstring1 = "hello world";  
    const char* pstring2 = "hello world";  
 
    if(str1 == str2) 
        printf("true,");
    else
        printf("false,");

    if(str3 == str4) 
        printf("true,");
    else
        printf("false,");

    if(pstring1 == pstring2) 
        printf("true\n");
    else
        printf("false\n");
        
    return 0;
}

A:false,false,true

B:false,false,false

C:true,true,true

D:false,true,true

答案及解析 A

本题考查的是比较变量是否相等

第一组

????????这一组比较的是数组名,数组名是首元素的地址,也就是比较两个地址是否相同,一定是不相同的,因为这是两个不同的变量,这两个变量都会在栈上开辟空间,然后分别存放字符串;

第二组和第一组一个道理

第三组

这个是在栈区上定义两个指针变量,指向的一个字符串,而这两个指针变量都是存的这个字符串的首元素地址。所以比较的就是这个字符串的首元素地址;但是这个字符串是在常量区定义的,所以上下两个字符串是一样的,因为我们系统很聪明,在常量区的字符串是只读的,不可以修改。所以没必要给你弄两个字符串。

文章来源:https://blog.csdn.net/2302_76941579/article/details/135115882
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。