一道关于指针数组的面试题

Posted 章无忌

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一道关于指针数组的面试题相关的知识,希望对你有一定的参考价值。

  指针数组:指针的数组,表示一个数组,并且数组的每一个元素都是指针类型。

  数组指针:数组的指针,表示一个指针,并且是指向数组的指针。

看看下面每行的分析,学习啦~

[cpp] view plain copy
 
  1. #include <iostream>  
  2. using namespace std;  
  3. int main ( )  
  4. {  
  5.     char *str[]={"welcome","to","fortemedia","Nanjing"};  
  6.     char * * p=str+1;     //p指向 "to"字符串地址  
  7.       
  8.     str[0]=(*p++) +2;          //str[0]指向‘\0‘;           然后p后移 p=str[2]  
  9.     str[1]=*(p+1);            //p+1后 p+1 = str[3];   然后 str[1] = str[3]           
  10.     str[2]=p[1]+3;             //str[2]指向str[3]的从0开始数的第三个 str[2]指向"jing"地址  
  11.     str[3]=p[0]+(str[2]-str[1]);  //str[3]指向从p[0]开始(也就是*p,也就是str[2])的 偏移量为(str[2]-str[1])的地址~ str[2]指向"jing",str[1]指向str[3],也就是"Namjing",所以str[3]指向"jing"的"g"地址  
  12.     printf("%s\n",str[0]);  
  13.     printf("%s\n",str[1]);  
  14.     printf("%s\n",str[2]);  
  15.     printf("%s\n",str[3]);  
  16.       
  17.     return 0;  
  18. }  

 

 

[cpp] view plain copy
 
  1. int main()  
  2. {  
  3.     char *str[] = {"Welcome","to","Fortemedia","Nanjing"};   
  4.     char **p = str + 1;   
  5.       
  6.     str[0] = *p++;   
  7. //{"to","to","Fortemedia","Nanjing"};  
  8.     str[1] = *(p+1);   
  9. //{"to","Nanjing","Fortemedia","Nanjing"};  
  10.     str[2] = p[1] + 3;   
  11. //{"to","Nanjing","jing","Nanjing"};  
  12.     str[3] = p[0] + (str[2] - str[1]);   
  13. //str[2]-str[1]是原来的指向Nanjing中的j的指针减去Nanjing中的N的指针,当然是3了  
  14. //p[0] 是指向"jing"中的j的,再加3就是g了  
  15.       
  16.     printf("%s\n",str[0]);   
  17.     printf("%s\n",str[1]);   
  18.     printf("%s\n",str[2]);   
  19.     printf("%s\n",str[3]);   
  20.     return 0;  
  21. }  

以上是关于一道关于指针数组的面试题的主要内容,如果未能解决你的问题,请参考以下文章

数组和指针关于「sizeof」 「strlen 」经典易错面试题

LeetCode 面试题 17.11单词距离[数组 双指针] HERODING的LeetCode之路

双指针算法:同向双指针模板以及相关面试题

一道微软面试题:“半”有序数组如何进行二分查找?

一道类数组的面试题

一道类数组的面试题