2005年华为招聘--C语言笔试试题
一、判断题(对的写T,错的写F并说明原因,每小题4分,共20分)
1、有数组定义int a[2][2]={{1},{2,3}};则a[0][1]的值为0。( T )
2、int (*ptr) (),则ptr是一维数组的名字。( F, ptr为一个函数指针 )
3、指针在任何情况下都可进行>,<,>=,<=,==运算。( F,指针比较大小没有任何意义,但是可以比较==与!= )
4、switch(c) 语句中c可以是int ,long,char ,float ,unsigned int 类型。( F,不可以为float )
5、#define print(x) printf("the no, "#x",is ") (T)
二、填空题(共30分)
1、在windows下,写出运行结果,每空2分,共10分。
char str[ ]= "Hello";
char *p=str;
int n=10;
sizeof(str)=( 6 )
sizeof(p)=( 4 )
sizeof(n)=( 4 )
void func(char str[100])
{ }
sizeof(str)=( 4 )
2、void setmemory(char **p, int num)
{ *p=(char *) malloc(num);}
void test(void)
{ char *str=NULL;
setmemory(&str,100);
strcpy(str,"hello");
printf(str);
}
运行test函数有什么结果?( hello )10分
3、设int arr[]={6,7,8,9,10};
int *ptr=arr;
*(ptr++)+=123;
printf("%d,%d",*ptr,*(++ptr));
( 8, 8 ) 10分
二、编程题(第一小题20,第二小题30分)
1、不使用库函数,编写函数int strcmp(char *source, char *dest) 相等返回0,不等返回-1;
#i nclude <stdio.h>
#i nclude <stdlib.h>
int mystrcmp(char *source, char *dest)
{
while(*source == *dest && *source != '\0' && *dest != '\0')
{
source++;
dest++;
}
if (*source =='\0' && *dest == '\0')
return 0;
else
return -1;
}
int main()
{
char *str1 = "abcde";
char *str2 = "abcd";
printf("ret = %d", mystrcmp(str1, str2));
return 0;
}
2、写一函数int fun(char *p)判断一字符串是否为回文,是返回1,不是返回0,出错返回-1
#i nclude <stdio.h>
#i nclude <stdlib.h>
int rollback(char *str)
{
char *p = str;
while(*(str++))
;
str-=2;
while(*(p++) == *(str--) && *p != '\0')
;
if (*p == '\0')
return 0;
else
return -1;
}
int main()
{
char *str1 = "abaaba";
printf("ret = %d", rollback(str1));
return 0;
}
3.请问C++的类和C里面的struct有什么区别?
答:struct的成员的默认访问说明符为Public,而class的成员的默认访问说明符为Private。其他没有区别
4.请讲一讲析构函数和虚函数的用法和作用。
答:析构函数是在对象生存期结束时自动调用的函数,用来释放在构造函数分配的内存。
虚函数是指被关键字virtual说明的函数,作用是使用C++语言的多态特性
5.全局变量和局部变量有什么区别?是怎么实现的?操作系统和编译器是怎么知道的?
答:一些变量在整个程序中都是可见的,它们称为全局变量。一些变量只能在一个函数中可知,称为局部变量。这就是他们的区别。
在任何函数外面定义的变量就是全局变量,在函数内部定义的变量是局部变量,这是它们在程序中的实现过程。
操作系统和编译器是根据程序运行的内存区域知道他们的,程序的全局数据放在所分配内存的全局数据区,程序的局部数据放在栈区。
6。有1,2,3,4,,,,n个数放在一个数组里,按大小排序,输出。 dYtf#q9v B
7。写一个算法,将一个数按高位到低位逆转,例如,用户输入123,则输出321。v_k0^X+Mf
初始的数据放入n,结果放入m
m=0;/oKfv9B
while(n>0)3o4Fk)W%w6]^Va+B
{
m=m*10+(n mod 10);
n=n\10;//整除/M'\;F7AR(V
}/|+.Lg.} a8EZ'c
8。抽象类和接口的区别是什么?
(1)接口可以被多重implements,抽象类只能被单一extends
(2)接口只有定义,抽象类可以有定义和实现
(3)接口的字段定义默认为:public static final, 抽象类字段默认是"friendly"