一道比较难以理解的指针题目

简介: 一道比较难以理解的指针题目

发布这篇博客的缘由


各位朋友们,大家好啊,今天我给大家分享的是一道我在C语言学习的过程中遇到的比较经典的一道指针题目。我希望通过这道题的分享能够让各位朋友知道,在做编程题的时候,画图的重要性,因为通过画图你能简单明了的知道题目所给的意思以及你思考的方法。


接下来就来看看这道题到底是一个怎样的题目呢?


题目

#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;
}

解答


大家第一眼看到这个题目是不是感觉头都开始发昏了,先别急,我来带大家一步一步的解决这个问题。那么首先呢,我们要做的就是画图。

34.png

当我们把图给画出来之后,我们的思路是不是一目了然了呢?我们先来看第一个打印:

printf("%s\n", **++cpp);

POINT这里cpp指向的是cp首元素的地址,那么++cpp了之后呢,就指向了cp首元素的下一个元素的地址,也就是存放c+2的地址,然后解引用拿到的是c+2,然后再解引用,就得到了c+2所指向的地址中存放的内容,所以这个打印就是"POINT"。

35.png

再看第二个打印

printf("%s\n", *-- * ++cpp + 3);

因为上一个打印,++cpp已经将cpp所指向的地址改变了,所以我们不能用cpp指向的原来的地址,cpp指向的是c+2所在的地址。这个打印我们还需要注意运算符的优先级,这里++、--和*是属于同一优先级的,运算顺序是从右到左进行的。++cpp使cpp指向的元素又移向下一个也就是c+1所在的地址,然后解引用拿到c+1,然后对c+1进行--,也就是c,这就说明原来cp中内容c+1被改为了c,然后解引用就得到了c的内容。c存放的是"ENTER"首字母的地址,然后+3就指向了ER的E,最后打印出来的就是ER。

image.png

第三个打印

printf("%s\n", *cpp[-2] + 3);

cpp[-2]就相当于*(cpp-2),所以cpp[-2]就得到的是cp首元素的内容c+3,然后再解引用就得到了c+3所指向的内容,也就是"FIRST"的首字母地址,再+3就指向了ST的S,最后打印出来的就是ST。这个过程中cpp的值并没有改变。


再看最后一个打印

printf("%s\n", cpp[-1][-1] + 1);

cpp[-1][-1]就可以改写成这样:*(*(cpp-1)-1),cpp-1指向了c+2所在的地址,解引用就拿到了c+2,然后-1得到c+1;继续解引用就得到c+1所指向的内容,也就是"NEW"的首元素地址,+1就指向了EW的E,打印出来就是EW。


image.png

最终的答案就是

38.png


结语


那么做完了这道题,大家是不是就能知道画图所带来的好处了吧 ,在做一个题目之前如果我们能画出这道题的解题思路,我们就能轻松的将这个题给做出来,并且正确率也会提高,我们一定要养成画图的好习惯。那么这就是今天我的所有分享,希望对大家能有帮助,感谢大家的观看。       ·

相关文章
|
6月前
|
C语言
C语言:数组和指针笔试题解析(包括一些容易混淆的指针题目)
C语言:数组和指针笔试题解析(包括一些容易混淆的指针题目)
|
6月前
|
存储 C语言 C++
C语言------------指针笔试题目深度剖析
C语言------------指针笔试题目深度剖析
44 1
|
存储 编译器 C语言
数组、指针练习题及解析(含笔试题目讲解)其一(上)
数组、指针练习题及解析(含笔试题目讲解)其一
100 0
|
存储 编译器 C语言
C语言: 数组指针/指针数组等相关的选择题目
C语言: 数组指针/指针数组等相关的选择题目
|
11月前
|
存储
1.C语言题目---指针类(基础)
1.C语言题目---指针类(基础)
58 1
|
3月前
|
存储 编译器 C语言
【C语言】指针练习题目
【C语言】指针练习题目
|
5月前
|
算法
【经典LeetCode算法题目专栏分类】【第7期】快慢指针与链表
【经典LeetCode算法题目专栏分类】【第7期】快慢指针与链表
|
5月前
|
算法 容器
【经典LeetCode算法题目专栏分类】【第1期】左右双指针系列:盛最多水的容器、接雨水、回文子串、三数之和
【经典LeetCode算法题目专栏分类】【第1期】左右双指针系列:盛最多水的容器、接雨水、回文子串、三数之和
|
5月前
|
存储 SQL 算法
LeetCode 题目 117:填充每个节点的下一个右侧节点指针 II
LeetCode 题目 117:填充每个节点的下一个右侧节点指针 II