简介
这个笔试是我昨天春招的C++笔试题目,题目考的是C++的基本的语法,并没有考试太难得编程题或者数据结构。由此可以看出我的C++基础有待提高。
以下极为笔试部分
1
int main() {
char str[] = "hello";
char* p = str;
int n = 10;
cout << "size of= " << (int)(sizeof(str)+sizeof(p)+sizeof(n));
return 0;
}
2
int main()
{
int a[3];
a[0] = 2; a[1] = 4; a[2] = 6;
int* p, * q;
p = a; q = &a[2];//q取数组a的地址,而地址就像每家每户的门牌号不随占用字节的多少变化
cout <<q<< " "<<q-p<<" "<<a[q - p];
return 0;
}
3
int main()
{
char string[10];
char* str1 = "0123456789";
strcpy(string, str1);
}
4
void swap(int* p1, int* p2)
{
int* p;
*p = *p1;//错误原因是p未初始化
*p1 = *p2;
*p2 = *p1;
}
int main()
{
int m = 10; int n = 20;
swap(&m, &n); cout << "m= " << m;
return 0;
}
在swap函数中,p是一个“野”指针,有可能指向系统区,导致程序运行的崩溃。在VC++中DEBUG运行时提示错误“Access Violation”。该程序应该改为:
swap( int* p1,int* p2 )
{
int p;
p = *p1;
*p1 = *p2;
*p2 = p;
}
5
int main() {
//char str[] = "string";//正确
//char str[7] = { 's','t','r','i','n','g' };//正确
//char str[10]; str = "string";//错误表达式必须为可修改的左值
char str[7]= { 's','t','r','i','n','g','\0' };//正确
cout << str<<" str的大小为: "<<sizeof(str);
}
6
struct pupil
{
char name[20];
int sex;
}pup,*p;
int main() {
p = &pup;
(*p).sex;
return 0;
}
7
int main() {
int iArray[10];
int* p = iArray;
int x = sizeof(p) / sizeof(iArray[0]);
cout << x;
return 0;
}
8
int main() {
int a = 2; int b = 2;
cout << a++ + b;
}
9
int main() {
int a = 1, b = 2, c = 3, d = 4,x;
x=a < b ? a : c < d ? c : d;
cout << x;
return 0;
}
10
int main() {
int a = 10;
int* p = &a;
*p = 100;
cout << *p + 1;
return 0;
}
11
在C语言中,要求运算数必须是整形的运算符是?
12
typedef struct A {
int a; char b; short c; short d;
};
int main() {
cout << sizeof(A)<<" "<<sizeof(short)<<" "<<sizeof(char);
}
13
int main() {
int a = 5, c = 2, d = 10, f = 2, g;
g = d - a / c * f;
cout << g;
}
14
int main() {
int x, y, z, k;
x = (y = 4, z = 16, k = 32);
cout << x;
return 0;
}
15
int main() {
int a = 5, g; double c = 2.0;
g = a / c + c / a;
cout << g;
return 0;
}
16
int main() {
int x = 072;//不是十进制
cout << x + 1;
return 0;
}
17
int main() {
char ch = 'A';
ch = (ch >= 'A' && ch <= 'Z') ? ch + 32 : ch;
cout << ch;
return 0;
}
看来老子拿offer还是有点艰难险阻啊!最后希望对你有些帮助。