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

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 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

目录
相关文章
|
12天前
使用指针访问数组元素
【10月更文挑战第30天】使用指针访问数组元素。
28 3
|
24天前
|
C语言
【c语言】指针就该这么学(1)
本文详细介绍了C语言中的指针概念及其基本操作。首先通过生活中的例子解释了指针的概念,即内存地址。接着,文章逐步讲解了指针变量的定义、取地址操作符`&`、解引用操作符`*`、指针变量的大小以及不同类型的指针变量的意义。此外,还介绍了`const`修饰符在指针中的应用,指针的运算(包括指针加减整数、指针相减和指针的大小比较),以及野指针的概念和如何规避野指针。最后,通过具体的代码示例帮助读者更好地理解和掌握指针的使用方法。
45 0
|
11天前
使用指针访问数组元素
【10月更文挑战第31天】使用指针访问数组元素。
24 2
|
20天前
|
算法 索引
单链表题+数组题(快慢指针和左右指针)
单链表题+数组题(快慢指针和左右指针)
24 1
|
23天前
|
C语言
【c语言】指针就该这么学(3)
本文介绍了C语言中的函数指针、typedef关键字及函数指针数组的概念与应用。首先讲解了函数指针的创建与使用,接着通过typedef简化复杂类型定义,最后探讨了函数指针数组及其在转移表中的应用,通过实例展示了如何利用这些特性实现更简洁高效的代码。
15 2
|
23天前
|
C语言
如何避免 C 语言中的野指针问题?
在C语言中,野指针是指向未知内存地址的指针,可能引发程序崩溃或数据损坏。避免野指针的方法包括:初始化指针为NULL、使用完毕后将指针置为NULL、检查指针是否为空以及合理管理动态分配的内存。
|
23天前
|
C语言
C语言:哪些情况下会出现野指针
C语言中,野指针是指指向未知地址的指针,通常由以下情况产生:1) 指针被声明但未初始化;2) 指针指向的内存已被释放或重新分配;3) 指针指向局部变量,而该变量已超出作用域。使用野指针可能导致程序崩溃或不可预测的行为。
|
23天前
|
编译器 C语言
【c语言】指针就该这么学(2)
本文详细介绍了指针与数组的关系,包括指针访问数组、一维数组传参、二级指针、指针数组和数组指针等内容。通过具体代码示例,解释了数组名作为首元素地址的用法,以及如何使用指针数组模拟二维数组和传递二维数组。文章还强调了数组指针与指针数组的区别,并通过调试窗口展示了不同类型指针的差异。最后,总结了指针在数组操作中的重要性和应用场景。
17 0
|
3天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
14 2
|
1月前
|
缓存 Java 程序员
Map - LinkedHashSet&Map源码解析
Map - LinkedHashSet&Map源码解析
66 0

推荐镜像

更多