C语言进阶⑫(指针下)(指针和数组笔试题解析)(杨氏矩阵)(中)

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: C语言进阶⑫(指针下)(指针和数组笔试题解析)(杨氏矩阵)

C语言进阶⑫(指针下)(指针和数组笔试题解析)(杨氏矩阵)(上):https://developer.aliyun.com/article/1513059

笔试题4:

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

解析:

 
#include<stdio.h>
int main()
{
    int a[3][2] = { (0, 1), (2, 3), (4, 5) };
    //()不是{}   是逗号表达式! 天坑  1  3
    //                            5  0
    //                            0  0
    int* p;
    p = a[0];
    printf("%d", p[0]);//p==a[0]   p[0]==a[0][0]==1
    return 0;
}

笔试题5:

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

解析:

 
#include<stdio.h>
int main()
{
    int a[5][5];
    int(*p)[4];
    p = a;
    printf("%p,%d\n", &p[4][2] - &a[4][2], &p[4][2] - &a[4][2]);
    return 0;
}
//a的类型是int(*)[5]+1跳过5*4个字节   p的类型是int(*)[4]  +1跳过4*4个字节
//答案是FFFFFFFC,-4    看图

能力有限,再看看佬的讲解:

笔试题6:

 
#include<stdio.h>
int main()
{
    int aa[2][5] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
    int* ptr1 = (int*)(&aa + 1);
    int* ptr2 = (int*)(*(aa + 1));
    printf("%d,%d", *(ptr1 - 1), *(ptr2 - 1));
    return 0;
}

解析:

 
#include<stdio.h>
int main()
{
    int aa[2][5] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
    int* ptr1 = (int*)(&aa + 1); //&aa整个数组的地址+1跳过整个数组
    int* ptr2 = (int*)(*(aa + 1));//首元素(首元素是第一行)地址+1,第二行地址
    //第二行首元素地址解引用得到6  int*没有意义,本来就是   *(aa + 1)相当于aa[1]
    printf("%d,%d", *(ptr1 - 1), *(ptr2 - 1));//指针减一(前一个元素):10,5 
    return 0;
}

笔试题7:

 
#include<stdio.h>
int main()
{
    char* a[] = { "work","at","alibaba" };
    char** pa = a;
    pa++;
    printf("%s\n", *pa);
    return 0;
}

解析:

 
#include<stdio.h>
int main()
{
    char* a[] = { "work","at","alibaba" };//指针数组
    char** pa = a;
    pa++;//跳过数组里的一个元素,跳到at的地址
    printf("%s\n", *pa);//at(%s从a开始向后打印字符串)
    return 0;
}

笔试题8:

 
#include<stdio.h>
int main()
{
    char* c[] = { "ENTER","NEW","POINT","FIRST" };
    char** cp[] = { c + 3,c + 2,c + 1,c };
    char*** cpp = cp;
    printf("%s\n", **++cpp);
    printf("%s\n", *-- * ++cpp + 3);
    printf("%s\n", *cpp[-2] + 3);
    printf("%s\n", cpp[-1][-1] + 1);
    return 0;
}

解析:哪一步不懂可以看看放在后面的佬的图

 
#include<stdio.h>
int main()
{
    char* c[] = { "ENTER","NEW","POINT","FIRST" };
    char** cp[] = { c + 3,c + 2,c + 1,c };
    char*** cpp = cp;
    printf("%s\n", **++cpp);//++cpp==c+2 解引用得c+2内容,即POINT地址 再解引用得POINT
    printf("%s\n", *-- * ++cpp + 3);//++cpp在上一行基础在+1得到c+1地址
    //解引用得c+1内容 再--得到c的内容 再解引用得到ENTER的地址即E的地址 
    //再+3得到第二个E的地址  打印出ER
    printf("%s\n", *cpp[-2] + 3);//*cpp[-2]==*(*(cpp-2))
    //cpp在上面内容-2得到c+3的内容  解引用得到c+3地址 再解引用得到FIRST地址
    //再+3得到S的地址  打印出ST
    printf("%s\n", cpp[-1][-1] + 1);//cpp[-1][-1]==*(*(cpp-1)-1)
    //++cpp等价于cpp=cpp+1  cpp变了 但cpp-2 cpp没有变 还是指向c+1
    //cpp在上面内容-1得到c+2的内容  解引用得到c+2地址 再-1得到c+1的地址
    //再解引用得到NEW的地址  再+1得到E的地址  打印出EW
    return 0;
}

可以一边看文字一边画图理解:(也可以配合调试)

佬的讲解:

C语言进阶⑫(指针下)(指针和数组笔试题解析)(杨氏矩阵)(下):https://developer.aliyun.com/article/1513066

目录
相关文章
|
19天前
使用指针访问数组元素
【10月更文挑战第30天】使用指针访问数组元素。
30 3
|
30天前
|
C语言
【c语言】指针就该这么学(1)
本文详细介绍了C语言中的指针概念及其基本操作。首先通过生活中的例子解释了指针的概念,即内存地址。接着,文章逐步讲解了指针变量的定义、取地址操作符`&`、解引用操作符`*`、指针变量的大小以及不同类型的指针变量的意义。此外,还介绍了`const`修饰符在指针中的应用,指针的运算(包括指针加减整数、指针相减和指针的大小比较),以及野指针的概念和如何规避野指针。最后,通过具体的代码示例帮助读者更好地理解和掌握指针的使用方法。
49 0
|
18天前
使用指针访问数组元素
【10月更文挑战第31天】使用指针访问数组元素。
29 2
|
26天前
|
算法 索引
单链表题+数组题(快慢指针和左右指针)
单链表题+数组题(快慢指针和左右指针)
30 1
|
29天前
|
C语言
【c语言】指针就该这么学(3)
本文介绍了C语言中的函数指针、typedef关键字及函数指针数组的概念与应用。首先讲解了函数指针的创建与使用,接着通过typedef简化复杂类型定义,最后探讨了函数指针数组及其在转移表中的应用,通过实例展示了如何利用这些特性实现更简洁高效的代码。
17 2
|
30天前
|
C语言
如何避免 C 语言中的野指针问题?
在C语言中,野指针是指向未知内存地址的指针,可能引发程序崩溃或数据损坏。避免野指针的方法包括:初始化指针为NULL、使用完毕后将指针置为NULL、检查指针是否为空以及合理管理动态分配的内存。
|
30天前
|
C语言
C语言:哪些情况下会出现野指针
C语言中,野指针是指指向未知地址的指针,通常由以下情况产生:1) 指针被声明但未初始化;2) 指针指向的内存已被释放或重新分配;3) 指针指向局部变量,而该变量已超出作用域。使用野指针可能导致程序崩溃或不可预测的行为。
|
1月前
|
存储 C语言
C语言32位或64位平台下指针的大小
在32位平台上,C语言中指针的大小通常为4字节;而在64位平台上,指针的大小通常为8字节。这反映了不同平台对内存地址空间的不同处理方式。
|
1月前
|
存储
如何使用指针数组来实现动态二维数组
指针数组可以用来实现动态二维数组。首先,定义一个指向指针的指针变量,并使用 `malloc` 为它分配内存,然后为每个子数组分配内存。通过这种方式,可以灵活地创建和管理不同大小的二维数组。
|
1月前
|
存储
如何通过指针数组来实现二维数组?
介绍了二维数组和指针数组的概念及其区别,详细讲解了如何使用指针数组模拟二维数组,包括定义与分配内存、访问和赋值元素、以及正确释放内存的步骤,适用于需要动态处理二维数据的场景。
下一篇
无影云桌面