没有合适的资源?快使用搜索试试~ 我知道了~
首页C++面试题 C++笔试题(微软、IBM、华为、微创、网通、百度)
主要内容包括: 微软亚洲技术支持中心面试题目、微创笔试题目(微创,微软在中国的合资公司)、Intel笔试面试题目、IBM笔试题目、阿尔卡特(中国)的面试题目、Google、 戴尔、Sony笔试题、华为笔试题、大唐电信、网通笔试题、中软融鑫笔试题、星巴克、威盛笔试试题、汉王笔试题、网易、百度笔试题、上海聚力传媒技术有限公司官方VC笔试题解答...
资源详情
资源评论
资源推荐

表示已有答案
表示没有处理
表示答案不确定
C++笔试题
1.多态类中的虚函数表是 Compile-Time,还是 Run-Time 时建立的?
答案:虚拟函数表是在编译期就建立了各个虚拟函数这时被组织成了一个虚拟函数的入口地址的
数组而对象的隐藏成员虚拟函数表指针是在运行期也就是构造函数被调用时进行初始化的这是
实现多态的关键
2.将一个 1M -10M 的文件,逆序存储到另一个文件,就是前一个文件的最后一个
字符存到新文件的第一个字符,以此类推。
3.main 主函数执行完毕后,是否可能会再执行一段代码?(朗讯的一道笔试题)
答案:可以,可以用注册一个函数,它会在 之后执行
如果你需要加入一段在 退出后执行的代码,可以使用 函数,注册一个函数。
语法:
!"#
$
!
"
#
%&'(&)
*
$
%&)
*
!
$
%&
*
"
$
%&
*
#
$
%&'

*
结果:
'(&
'
4.一个父类写了一个 virtual 函数,如果子类覆盖它的函数不加 virtual ,也能实现多态?
在子类的空间里,有没有父类的这个函数,或者父类的私有变量? (华为笔试题)
答案:只要基类在定义成员函数时已经声明了 关键字,在派生类实现的时候覆盖该函数时, 关键字可
加可不加,不影响多态的实现。子类的空间里有父类的所有变量(static 除外)。
5.给一个字符串、例如 “ababc”要求返回“ab”. 因为“ab”连续重复出现且最长。
用 C/C++语言写一函数完成该算法,给出复杂度
6.对序列 1、1、2、3、5、8、13。。。。 是 Fab..数列
2、3、5、13...是 Fab..质数数列,因为他们与自己前面的 Fab...数列都互质
给出 k,返回第 k 小的 Fab..质数
7.101 个硬币 100 真、1 假,真假区别在于重量。请用无砝码天平称两次给出真币重还是假币
重的结论。
8.完成字符串拷贝可以使用 sprintf、strcpy 及 memcpy 函数,请问这些函数有什么区别
,你喜欢使用哪个,为什么?
答案:这些函数的区别在于 实现功能 以及 操作对象 不同。
&%+函数操作的对象是 字符串,完成 从 源字符串 到 目的字符串 的 拷贝 功能。
!%&函数操作的对象不限于字符串:虽然目的对象是字符串,但是源对象可以是字符串、也可以
是任意基本类型的数据。这个函数主要用来实现(字符串或基本数据类型)向字符串的转换功能。如果
源对象是字符串,并且指定 ,格式符,也可实现字符串拷贝功能。
"%+函数顾名思义就是 内存拷贝,实现 将一个 内存块 的内容复制到另一个 内存块 这一功能。
内存块由其首地址以及长度确定。程序中出现的实体对象,不论是什么类型,其最终表现就是在内存中
占据一席之地(一个内存区间或块)。因此,%+的操作对象不局限于某一类数据类型,或者说
可 适用于任意数据类型,只要能给出对象的起始地址和内存长度信息、并且对象具有可操作性即可。鉴
于 %+函数等长拷贝的特点以及数据类型代表的物理意义,%+函数通常限于同种类型数
据或对象之间的拷贝,其中当然也包括字符串拷贝以及基本数据类型的拷贝。
对于字符串拷贝来说,用上述三个函数都可以实现,但是其实现的效率和使用的方便程度不同:
&%+无疑是最合适的选择:效率高且调用方便。
%&要额外指定格式符并且进行格式转化,麻烦且效率不高。
%+虽然高效,但是需要额外提供拷贝的内存长度这一参数,易错且使用不便;并且如果
长度指定过大的话(最优长度是源字符串长度 - ),还会带来性能的下降。其实 &%+函
数一般是在内部调用 %+函数或者用汇编直接实现的,以达到高效的目的。因此,使用
%+和 &%+拷贝字符串在性能上应该没有什么大的差别。
对于非字符串类型的数据的复制来说,&%+和 %&一般就无能为力了,可是对 %+
却没有什么影响。但是,对于基本数据类型来说,尽管可以用 %+进行拷贝,由于有赋值运
算符可以方便且高效地进行同种或兼容类型的数据之间的拷贝,所以这种情况下 %+几乎不

被使用。%+的长处是用来实现(通常是内部实现居多)对结构或者数组的拷贝,其目的是
或者高效,或者使用方便,甚或两者兼有。
9.变量的声明和定义有什么区别?
10.请写出下面代码在 32 位平台上的运行结果,并说明 sizeof 的性质:
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
char a[30];
char *b = (char *)malloc(20 * sizeof(char));
printf("%d\n", sizeof(a));
printf("%d\n", sizeof(b));
printf("%d\n", sizeof(a[3]));
printf("%d\n", sizeof(b+3));
printf("%d\n", sizeof(*(b+4)));
return 0 ;
}
12.请完成以下题目。注意,请勿直接调用 ANSI C 函数库中的函数实现。
a)请编写一个 C 函数,该函数给出一个字节中被置 1 的位的个数,并请给出该题的至少一个不同
解法。
第一种 .'/01&.
$
.21
&213--
$
2.44移位
5211 44与 相与
--
*
&&
*
第二种 .'/0 &.
$
.21
&213--
$
26.44反码?
5211144与 1 相与
7
--

*
&&
*
请编写一个 8函数,该函数将给定的一个字符串转换成整数。
9&&&
$
21
:&72;)1;
$
.2
2 1-.
&2&-
*
&&
*
请编写一个 8函数,该函数将给定的一个整数转换成字符串。
9'8&8.&%
$
&&< 11=
>
121
21
12
&21 11--
$
21, 144取余
1214 144取整
&<=2 -#344数字—字符
1 1
$
--
&<=21-#3
&?
*
*
&>21>2>--44倒置
$
%<>=2&<>=
*
%<>=2;)1;
*
请编写一个 8函数,该函数将一个字符串逆序。
/@&&&
$

&&< 11=
>21
:&<>=44放入 &,<>=为长度
$
&<>=2&<>=
>--
>AA
$
&&
*
*
&<>=2;)1;
&21>--
$
<=2&<> =44反序
*
<=2;)1;
*
请编写一个 8函数,该函数在给定的内存区域搜索给定的字符,并返回该字符所在位置索引值。
起始地址,搜索长度,目标字符
请编写一个 8函数,该函数在一个字符串中找到可能的最长的子字符串,该字符串是由同一字
符组成的。
8B&.&%44自己写
$
8&C2%
&.2121>2 212
:C72D)1D44不能用 &求得长度 &.
$
B&.--
C--
*
:B&.
$
%-22%->55>B&.
$
--44统计子串长度
剩余63页未读,继续阅读

















安全验证
文档复制为VIP权益,开通VIP直接复制

评论30