华为C++笔试题.docx

上传人:b****3 文档编号:5294415 上传时间:2022-12-15 格式:DOCX 页数:18 大小:23.04KB
下载 相关 举报
华为C++笔试题.docx_第1页
第1页 / 共18页
华为C++笔试题.docx_第2页
第2页 / 共18页
华为C++笔试题.docx_第3页
第3页 / 共18页
华为C++笔试题.docx_第4页
第4页 / 共18页
华为C++笔试题.docx_第5页
第5页 / 共18页
点击查看更多>>
下载资源
资源描述

华为C++笔试题.docx

《华为C++笔试题.docx》由会员分享,可在线阅读,更多相关《华为C++笔试题.docx(18页珍藏版)》请在冰豆网上搜索。

华为C++笔试题.docx

华为C++笔试题

1.static有什么用途?

(请至少说明两种)

1)在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。

2)在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。

它是一个本地的全局变量。

3)在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。

那就是,这个函数被限制在声明它的模块的本地范围内使用

2.引用与指针有什么区别?

1)引用必须被初始化,指针不必。

2)引用初始化以后不能被改变,指针可以改变所指的对象。

3)不存在指向空值的引用,但是存在指向空值的指针。

3.描述实时系统的基本特性

在特定时间内完成特定的任务,实时性与可靠性。

4.全局变量和局部变量在内存中是否有区别?

如果有,是什么区别?

全局变量储存在静态数据库,局部变量在堆栈。

5.什么是平衡二叉树?

左右子树都是平衡二叉树且左右子树的深度差值的绝对值不大于1。

6.堆栈溢出一般是由什么原因导致的?

没有回收垃圾资源。

7.什么函数不能声明为虚函数?

constructor函数不能声明为虚函数。

8.冒泡排序算法的时间复杂度是什么?

时间复杂度是O(n^2)。

9.写出floatx与“零值”比较的if语句。

if(x>0.000001&&x<-0.000001)

10.Internet采用哪种网络协议?

该协议的主要层次结构?

Tcp/Ip协议

主要层次结构为:

应用层/传输层/网络层/数据链路层/物理层。

11.Internet物理地址和IP地址转换采用什么协议?

ARP(AddressResolutionProtocol)(地址解析協議)

12.IP地址的编码分为哪俩部分?

IP地址由两部分组成,网络号和主机号。

不过是要和“子网掩码”按位与上之后才能区分哪些是网络位哪些是主机位。

13.用户输入M,N值,从1至N开始顺序循环数数,每数到M输出该数值,直至全部输出。

写出C程序。

循环链表,用取余操作做

14.不能做switch()的参数类型是:

switch的参数不能为实型。

 

1.以下三条输出语句分别输出什么?

[C易]

charstr1[]="abc";

charstr2[]="abc";

constcharstr3[]="abc";

constcharstr4[]="abc";

constchar*str5="abc";

constchar*str6="abc";

cout<

cout<

cout<

 

2.非C++内建型别A和B,在哪几种情况下B能隐式转化为A?

[C++中等]

答:

a.classB:

publicA{……}//B公有继承自A,可以是间接继承的

b.classB{operatorA();}//B实现了隐式转化为A的转化

c.classA{A(constB&);}//A实现了non-explicit的参数为B(可以有其他带默认值的参数)构造函数

d.A&operator=(constA&);//赋值操作,虽不是正宗的隐式类型转换,但也可以勉强算一个

3.以下代码中的两个sizeof用法有问题吗?

[C易]

voidUpperCase(charstr[])//将str中的小写字母转换成大写字母

{

for(size_ti=0;i

if('a'<=str[i]&&str[i]<='z')

str[i]-=('a'-'A');

}

charstr[]="aBcDe";

cout<<"str字符长度为:

"<

UpperCase(str);

cout<

4.以下代码有什么问题?

[C难]

voidchar2Hex(charc)//将字符以16进制表示

{

charch=c/0x10+'0';if(ch>'9')ch+=('A'-'9'-1);

charcl=c%0x10+'0';if(cl>'9')cl+=('A'-'9'-1);

cout<

}

charstr[]="Ilove中国";

for(size_ti=0;i

char2Hex(str[i]);

cout<

5.以下代码有什么问题?

[C++易]

structTest

{

Test(int){}

Test(){}

voidfun(){}

};

voidmain(void)

{

Testa

(1);

a.fun();

Testb();

b.fun();

}

6.以下代码有什么问题?

[C++易]

cout<<(true?

1:

"1")<

7.以下代码能够编译通过吗,为什么?

[C++易]

unsignedintconstsize1=2;

charstr1[size1];

unsignedinttemp=0;

cin>>temp;

unsignedintconstsize2=temp;

charstr2[size2];

8.以下代码中的输出语句输出0吗,为什么?

[C++易]

structCLS

{

intm_i;

CLS(intI):

m_i(i){}

CLS()

{

CLS(0);

}

};

CLSobj;

cout<

9.C++中的空类,默认产生哪些类成员函数?

[C++易]

答:

classEmpty

{

public:

Empty();//缺省构造函数

Empty(constEmpty&);//拷贝构造函数

~Empty();//析构函数

Empty&operator=(constEmpty&);//赋值运算符

Empty*operator&();//取址运算符

constEmpty*operator&()const;//取址运算符const

};

10.以下两条输出语句分别输出什么?

[C++难]

floata=1.0f;

cout<<(int)a<

cout<<(int&)a<

cout<

Floatb=0.0f;

cout<<(int)b<

cout<<(int&)b<

cout<

11.以下反向遍历array数组的方法有什么错误?

[STL易]

vectorarray;

array.push_back

(1);

array.push_back

(2);

array.push_back(3);

for(vector:

:

size_typei=array.size()-1;i>=0;--I)//反向遍历array数组

{

cout<

}

12.以下代码有什么问题?

[STL易]

typedefvectorIntArray;

IntArrayarray;

array.push_back

(1);

array.push_back

(2);

array.push_back

(2);

array.push_back(3);

//删除array数组中所有的2

for(IntArray:

:

iteratoritor=array.begin();itor!

=array.end();++itor)

{

if(2==*itor)array.erase(itor);

}

13.写一个函数,完成内存之间的拷贝。

[考虑问题是否全面]

答:

void*mymemcpy(void*dest,constvoid*src,size_tcount)

{

char*pdest=static_cast(dest);

constchar*psrc=static_cast(src);

if(pdest>psrc&&pdest

{

for(size_ti=count-1;i!

=-1;--I)

pdest[i]=psrc[i];

}

else

{

for(size_ti=0;i

pdest[i]=psrc[i];

}

returndest;

}

intmain(void)

{

mymemcpy(str+1,str+0,9);

cout<

system("Pause");

return0;

}

 

本试题仅用于考查C++/C程序员的基本编程技能。

内容限于C++/C常用语法,不涉及数据结构、算法以及深奥的语法。

考试成绩能反映出考生的编程质量以及对C++/C的理解程度,但不能反映考生的智力和软件开发能力。

笔试时间90分钟。

请考生认真答题,切勿轻视。

 

一、请填写BOOL,float,指针变量与“零值”比较的if语句。

(10分)

提示:

这里“零值”可以是0,0.0,FALSE或者“空指针”。

例如int变量n与“零值”比较的if语句为:

if(n==0)

if(n!

=0)

以此类推。

请写出BOOLflag与“零值”比较的if语句:

请写出floatx与“零值”比较的if语句:

请写出char*p与“零值”比较的if语句:

二、以下为WindowsNT下的32位C++程序,请计算sizeof的值(10分)

charstr[]=“Hello”;

char*p=str;

intn=10;

请计算

sizeof(str)=

sizeof(p)=

sizeof(n)=

voidFunc(charstr[100])

{

请计算

sizeof(str)=

}

void*p=malloc(100);

请计算

sizeof(p)=

三、简答题(25分)

1、头文件中的ifndef/define/endif干什么用?

2、#include和#include“filename.h”有什么区别?

3、const有什么用途?

(请至少说明两种)

4、在C++程序中调用被C编译器编译后的函数,为什么要加extern“C”声明?

5、请简述以下两个for循环的优缺点

//第一个

for(i=0;i++;)

{

if(condition)

DoSomething();

else

DoOtherthing();

}

//第二个

if(condition)

{

for(i=0;i++;)

DoSomething();

}

else

{

for(i=0;i++;)

DoOtherthing();

}

优点:

缺点:

优点:

缺点:

四、有关内存的思考题(20分)

voidGetMemory(char*p)

{

p=(char*)malloc(100);

}

voidTest(void)

{

char*str=NULL;

GetMemory(str);

strcpy(str,"helloworld");

printf(str);

}

 

请问运行Test函数会有什么样的结果?

答:

char*GetMemory(void)

{

charp[]="helloworld";

returnp;

}

voidTest(void)

{

char*str=NULL;

str=GetMemory();

printf(str);

}

 

请问运行Test函数会有什么样的结果?

答:

VoidGetMemory2(char**p,intnum)

{

*p=(char*)malloc(num);

}

voidTest(void)

{

char*str=NULL;

GetMemory(&str,100);

strcpy(str,"hello");

printf(str);

}

请问运行Test函数会有什么样的结果?

答:

voidTest(void)

{

char*str=(char*)malloc(100);

strcpy(str,“hello”);

free(str);

if(str!

=NULL)

{

strcpy(str,“world”);

printf(str);

}

}

请问运行Test函数会有什么样的结果?

答:

五、编写strcpy函数(10分)

已知strcpy函数的原型是

char*strcpy(char*strDest,constchar*strSrc);

其中strDest是目的字符串,strSrc是源字符串。

(1)不调用C++/C的字符串库函数,请编写函数strcpy

(2)strcpy能把strSrc的内容复制到strDest,为什么还要char*类型的返回值?

六、编写类String的构造函数、析构函数和赋值函数(25分)

已知类String的原型为:

classString

{

public:

String(constchar*str=NULL);//普通构造函数

String(constString&other);//拷贝构造函数

~String(void);//析构函数

String&operate=(constString&other);//赋值函数

private:

char*m_data;//用于保存字符串

};

请编写String的上述4个函数。

 

附录C:

C++/C试题的答案与评分标准

一、请填写BOOL,float,指针变量与“零值”比较的if语句。

(10分)

请写出BOOLflag与“零值”比较的if语句。

(3分)

标准答案:

if(flag)

if(!

flag)

如下写法均属不良风格,不得分。

If(flag==TRUE)

if(flag==1)

if(flag==FALSE)

if(flag==0)

请写出floatx与“零值”比较的if语句。

(4分)

标准答案示例:

constfloatEPSINON=0.00001;

if((x>=-EPSINON)&&(x<=EPSINON)

不可将浮点变量用“==”或“!

=”与数字比较,应该设法转化成“>=”或“<=”此类形式。

如下是错误的写法,不得分。

If(x==0.0)

if(x!

=0.0)

 

请写出char*p与“零值”比较的if语句。

(3分)

标准答案:

if(p==NULL)

if(p!

=NULL)

如下写法均属不良风格,不得分。

If(p==0)

if(p!

=0)

if(p)

if(!

二、以下为WindowsNT下的32位C++程序,请计算sizeof的值(10分)

charstr[]=“Hello”;

char*p=str;

intn=10;

请计算

sizeof(str)=6(2分)

sizeof(p)=4(2分)

sizeof(n)=4(2分)

voidFunc(charstr[100])

{

请计算

sizeof(str)=4(2分)

}

void*p=malloc(100);

请计算

sizeof(p)=4(2分)

三、简答题(25分)

1、头文件中的ifndef/define/endif干什么用?

(5分)

答:

防止该头文件被重复引用。

2、#include和#include“filename.h”有什么区别?

(5分)

华为的C\C++面试题

Q1:

请你分别划划OSI的七层网络结构图,和TCP/IP的五层结构图?

:

Q2:

请你详细的解释一下IP协议的定义,在哪个层上面,主要有什么作用?

:

TCP与UDP呢?

:

总得来说前面两道题目还是比较简单的!

:

Q3:

请问交换机和路由器分别的实现原理是什么?

分别在哪个层次上面实

:

现的?

:

Q4:

请问C++的类和C里面的struct有什么区别?

:

Q5:

请讲一讲析构函数和虚函数的用法和作用?

:

Q6:

全局变量和局部变量有什么区别?

实怎么实现的?

操作系统和编译器

:

是怎么知道的?

:

Q7:

一些寄存器的题目,我忘记了具体实什么题目,主要好像是寻址和内

:

存管理等一些知识,不记得了。

:

Q8:

8086是多少尉的系统?

在数据总线上是怎么实现的?

还有一些硬件方

:

面的知识我既不清楚了。

:

一般建议参加华为的研发面试的同学先要准备一下相关的知识,软件的主要

:

是看看C和数据结构方面的,硬件模电,数电和微机原理

两道c面试题

1、一个学生的信息是:

姓名,学号,性别,年龄等信息,用一个链表,把这些学生信息连在一起,给出一个age,在些链表中删除学生年龄等于age的学生信息。

程序代码

#Include"stdio.h"

#Include"conio.h"

structstu{

charname[20];

charsex;

intno;

intage;

structstu*next;

}*linklist;

structstu*creatlist(intn)

{

intI;

//h为头结点,p为前一结点,s为当前结点

structstu*h,*p,*s;

h=(structstu*)malloc(sizeof(structstu));

h->next=NULL;

p=h;

for(i=0;i

{

s=(structstu*)malloc(sizeof(structstu));

p->next=s;

printf("Pleaseinputtheinformationofthestudent:

namesexnoage\n");

scanf("%s%c%d%d",s->name,&s->sex,&s->no,&s->age);

s->next=NULL;

p=s;

}

printf("Createsuccessful!

");

return(h);

}

voiddeletelist(structstu*s,inta)

{

structstu*p;

while(s->age!

=a)

{

p=s;

s=s->next;

}

if(s==NULL)

printf("Therecordisnotexist.");

else

{

p->next=s->next;

printf("Deletesuccessful!

");

}

}

voiddisplay(structstu*s)

{

s=s->next;

while(s!

=NULL)

{

printf("%s%c%d%d\n",s->name,s->sex,s->no,s->age);

s=s->next;

}

}

intmain()

{

structstu*s;

intn,age;

printf("Pleaseinputthelengthofseqlist:

\n");

scanf("%d",&n);

s=creatlist(n);

display(s);

printf("Pleaseinputtheage:

\n");

scanf("%d",&age);

deletelist(s,age);

display(s);

return0;

}

2、实现一个函数,把一个字符串中的字符从小写转为大写。

程序代码

#Include"stdio.h"

#Include"conio.h"

voiduppers(char*s,char*us)

{

for(;*s!

='\0';s++,us++)

{

if(*s>='a'&&*s<='z')

*us=*s-32;

else

*us=*s;

}

*us='\0';

}

intmain()

{

char*s,*us;

charss[20];

printf("Pleaseinputastring:

\n");

scanf("%s",ss);

s=ss;

uppers(s,us);

printf("Theresultis:

\n%s\n",us);

getch();

}

 

1.进程和线程的差别。

2.测试方法

3.Heap与stack的差别。

4.Windows下的内存是如何管理的?

5.介绍.Net和.Net的安全性。

6.客户端如何访问.Net组件实现WebService?

7.C/C++编译器中虚表是如何完成的?

8.谈谈COM的线程模型。

然后讨论进程内/外组件的差别。

9.谈谈IA32下的分页机制

10.给两个变量,如何找出一个带环单链表中是什么地方出现环的?

11.在IA32中一共有多少种办法从

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 自然科学 > 物理

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1