原文作者:aircraft
原文链接:https://www.cnblogs.com/DOMLX/p/10713204.html
一套面试题的目录在此,还在继续完善中。。。。。。
c/c++ 2019面试题目录
1.利用指针交换两个字符串方法?(这题是我当年读大一的时候看到的,好怀念!!!QAQ)
(一)指针引用
#include<iostream>
using namespace std;
void swap(char *&a,char *&b)
{
char *temp;
temp = a;
a = b;
b = temp;
}
int main()
{
char *ap = "hello";
char *bp = "word";
swap(ap,bp);
cout<<"ap:"<<ap<<endl;
cout<<"bp:"<<bp<<endl;
return 0;
}
(二)二维指针指向一维
#include<iostream>
using namespace std;
void swap(char **a,char **b)
{
char *temp;
temp = *a;
*a = *b;
*b = temp;
}
int main()
{
char *ap = "hello";
char *bp = "word";
swap(&ap,&bp);
cout<<"ap:"<<ap<<endl;
cout<<"bp:"<<bp<<endl;
return 0;
}
2.参数引用--查找下面程序错误
#include<iostream> using namespace std; const float pi = 3.14f; float f; float f1(float r) { f = r*r*pi; return f; } float &f2(float r) { f = r*r*pi; return f; } int main() { float f1(float=5); float &f2(float=5); float a = f1(); float &b = f1(); //虽然返回的好像是一个全局变量,但是函数在处理的时候 //编译器机制返回的依然是一个临时建立的temp变量里面存放的是f内的值,对其进行引用报错 float c = f2(); float &d = f2();//函数定义返回值的时候加了引用,此时不会生成临时变量 //直接返回全局变量f,这种定义最节省空间,但是要注意全局变量f生存周期要大于引用d //这里是安全的 d += 1.0f; cout<<"a:"<<a<<endl; cout<<"b:"<<b<<endl; cout<<"c:"<<c<<endl; cout<<"d:"<<d<<endl; cout<<"f:"<<f<<endl; return 0; }
3.下面输出是什么?
int a[5]={1,2,3,4,5};
int *ptr=(int *)(&a+1);
printf("%d,%d/n",*(a+1),*(ptr-1));
答案:输出:2,5
*(a+1)就是a[1],*(ptr-1)就是a[4],执行结果是2,5
&a+1不是首地址+1,系统会认为加一个a数组的偏移,是偏移了一个数组的大小(本例是5个int)
&a是数组指针,其类型为 int (*)[5];
4.复杂的指针声明
简单级别:
a-一个整型数
b-一个指向整型数的指针
c-一个指向指针的指针,它指向的指针是指向一个整型数的
d-一个有十个整型数的数组
e-一个有十个指针的数组,该指针指向一个整型数
f-一个指向十个整型数数组的指针
g-一个指向函数的指针,该函数有一个整型参数并返回一个整型数
答案:
a: int a;
b: int *a;
c: int **a;
d: int a[10];
e: int *a[10];
f: int (*a)[10];
g: int (*a)(int);
复杂级别:
a-一个有十个指针的数组,该指针指向一个函数,该函数有一个整型参数并返回一个整型数
b-func是一个指向数组的指针,这个数组的元素是函数指针,这些指针指向有int*类型的形参,返回值为Int类型的函数
c-func是一个函数指针,这类函数具有int*类型的形参,返回值是指向数组的指针,所指向的元素是5个int元素的数组
答案:
a: int (*a[10])(int);
b: int (*(func)[5])(int *p);
c: int(*(func)(int *p))[5];
5.指针数组与数组指针(这个大一刚学的时候真的很混乱!!)
(不管是数组指针还是指针数组,像这像的词前半区都是修饰词,修辞后面,数组指针本质是个指针,指向一个数组。指针数组本质是个数组,数组里存放的是指针)
---同理:指针常量和常量指针。函数指针和指针函数都可以这么理解
数组指针(也称行指针)
定义 int (*p)[n];
()优先级高,首先说明p的本质是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。如要将二维数组赋给一指针,应这样赋值:
int a[3][4];
int (*p)[4]; //该语句是定义一个数组指针,指向含4个元素的一维数组。
p=a; //将该二维数组的首地址赋给p,也就是a[0]或&a[0][0]
p++; //该语句执行过后,也就是p=p+1;p跨过行a[0][]指向了行a[1][]所以数组指针也称指向一维数组的指针,亦称行指针。
指针数组
定义 int *p[n];
[]优先级高,先与p结合成为一个数组,再由int*说明这是一个整型指针数组,它有n个指针类型的数组元素。这里执行p+1时,则p指向下一个数组元素,这样赋值是错误的:p=a;因为p是个不可知的表示,只存在p[0]、p[1]、p[2]...p[n-1],而且它们分别是指针变量可以用来存放变量地址。但可以这样 *p=a; 这里*p表示指针数组第一个元素的值,a的首地址的值。
如要将二维数组赋给一指针数组:
int *p[3];
int a[3][4];
p++; //该语句表示p数组指向下一个数组元素。注:此数组每一个元素都是一个指针
for(i=0;i<3;i++)
p[i]=a[i]
这里int *p[3] 表示一个一维数组内存放着三个指针变量,分别是p[0]、p[1]、p[2]
所以要分别赋值。这样两者的区别就豁然开朗了,数组指针只是一个指针变量,似乎是C语言里专门用来指向二维数组的,它占有内存中一个指针的存储空间。指针数组是多个指针变量,以数组形式存在内存当中,占有多个指针的存储空间。
还需要说明的一点就是,同时用来指向二维数组时,其引用和用数组名引用都是一样的。
比如要表示数组中i行j列一个元素:
*(p[i]+j)、*(*(p+i)+j)、(*(p+i))[j]、p[i][j]优先级:()>[]>*
6.下面输出的是什么?
int main()
{
char * str[] = {"Welcome","to","Forteedia","Nanjing"} ;
char **p = str + 1;
str[0] = (*p++) +2;
str[1] = *(p+1);
str[2] = p[1] + 3 ;
str[3] = p[0] + (str[2] - str[1]);
printf("%s
",str[0]);
printf("%s
",str[1]);
printf("%s
",str[2]);
printf("%s
",str[3]);
return 0;
}
答案:
(空)
Nanjing
jing
g
其他应该没有疑问就说一下第一个空 。
char **p = str + 1; 这句指向“to”
str[0] = (*p++) +2;这里(*p++),p本身为一个二维指针,*号已经是指向一维。++的优先级高于*,意思就是*(p++)
但是后置++先执行完此行代码在自加的 先不管
这里如果是*p+1的话那么str【0】输出的是“o”,
也就是*p指向“to”的t,*p+1指向o,*p+2指向“to”之后的字符串结尾符“