试卷网址:https://www.nowcoder.com/profile/3571951/test/13714416/44774#summary
1、C++ inline关键字
正确答案: D 你的答案: 空 (错误)
使用inline关键字的函数会被编译器在调用处展开
头文件中可以包含inline函数的声明
可以在同一个项目的不同源文件内定义函数名相同但实现不同的inline函数
定义在Class声明内的成员函数默认是inline函数
优先使用Class声明内定义的inline函数
优先使用Class实现的内inline函数的实现
A 项错误,因为使用 inline 关键字的函数只是用户希望它成为内联函数,但编译器有权忽略这个请求,比如:若此函数体太大,则不会把它作为内联函数展开的。
B 项错误,头文件中不仅要包含 inline 函数的声明,而且必须包含定义,且在定义时必须加上 inline 。【关键字 inline 必须与函数定义体放在一起才能使函数成为内联,仅将 inline 放在函数声明前面不起任何作用】
C 项错误, inline 函数可以定义在源文件中,但多个源文件中的同名 inline 函数的实现必须相同。一般把 inline 函数的定义放在头文件中更加合适。
D 项正确,类内的成员函数,默认都是 inline 的。【定义在类声明之中的成员函数将自动地成为内联函数】
EF 项无意思,不管是 class 声明中定义的 inline 函数,还是 class 实现中定义的 inline 函数,不存在优先不优先的问题,因为因为 class 的成员函数都是 inline 的,加了关键字 inline 也没什么特殊的。
2、第二题和第十五题,排序算法的时间复杂度(参见博客 http://blog.youkuaiyun.com/qq_30141957/article/details/79428381)
19、结构体占用内存大小(参考博客 http://blog.youkuaiyun.com/qq_30141957/article/details/79433090)
struct st
{
int *p;
int i;
char a;
};
int sz=sizeof(struct st);
如下C程序,在64位处理器上运行后sz的值是什么?
知识点:
1、struct的对齐原则,没有指定#pragma pack(n)的情况下,32位默认4字节对齐,64位系统默认8字节对齐。
2、32位系统下,指针变量int*、char*等占用4字节,64位系统下,指针变量均占用8字节。
char=1; short=2; int=4; unsigned int=4; float=4; double=8; long=4;long long=8; unsigned long=4;
内存结构为: 1111 1111 1111 1xxx 成员总大小=13,由于需要补齐8的倍数,圆整=16
20、C语言 vector(参考http://blog.youkuaiyun.com/duan19920101/article/details/50617190/)
#include <iostream>
#include <vector>
using namespace std;
int main(void)
{
vector<int>array;
array.push_back(100);
array.push_back(300);
array.push_back(300);
array.push_back(300);
array.push_back(300);
array.push_back(500);
vector<int>::iterator itor;
for(itor=array.begin();itor!=array.end();itor++)
{
if(*itor==300)
{
itor=array.erase(itor);
}
}
for(itor=array.begin();itor!=array.end();itor++)
{
cout<<*itor<<"";
}
return 0;
}
正确答案: C 你的答案: E (错误)
100 300 300 300 300 500
100 3OO 300 300 500
100 300 300 500
100 300 500
100 500
程序错误
22、字符串查找
给定的一个长度为N的字符串str,查找长度为P(P<N)的字符串在str中的出现次数.下面的说法正确的是()
正确答案: D 你的答案: E (错误)
不存在比最坏时间复杂度O(NP)好的算法
不存在比最坏时间复杂度O(N^2)好的算法
不存在比最坏时间复杂度O(P^2)好的算法
存在最坏时间复杂度为O(N+P)的算法
存在最坏时间复杂度为O(log(N+P))的算法
以上都不对