C++面试题
2015-09-17 22:33
357 查看
在switch-case语句中,多个case可以共用一条执行语句,如:
case 常量表达式1:
case 常量表达式2:
case 常量表达式3:
语句;
break;
由此可以看出case语句的作用:
case后面的常量表达式实际上只起语句标号作用,而不起条件判断作用,即“只是开始执行处的入口标号”。
因此,一旦与switch后面圆括号中表达式的值匹配,就从此标号处开始执行;
而且执行完一个case后面的语句后,若没遇到break语句,就自动进入下一个case继续执行,而不再判断是否与之匹配,直到遇到break语句才停止执行,退出switch语句。
因此,若想执行一个case分之后立即跳出switch语句,就必须在此分支的最后添加一个break语句。
0.5在C++中默认是double类型,0.5f表示float类型
【分析】
先分析一下函数的复杂度:
f(n) = f(n-1)+f(n-2)+....+f(2)+f(1)
+f(0)
= 2( f(n-2)+ f(n-3)+....+f(2)+f(1)
+f(0))
=4( f(n-3) +f(n-4)+....+f(2)+f(1)
+f(0))
...
= 2^(n-1)*f(0)
复杂度为O(2^(n-1))
n = 35时,计算量为2^34
主流PC机的每秒钟计算量约为10^7~10^8次
因此计算时间大约在几分钟
相关文章推荐
- 字符替换 利用c++string类型
- 关于C语言中数据类型的转化方式
- C语言中的break、continue和goto语句
- C++Primer Plus 第十一章-运算符重载和友元函数
- C语言中经常遇到的问题:执行时显示进度条,然后卡住
- C语言中的switch语句
- C/C++堆栈详解
- 问题之编程语言_c语言_无符号计算
- C++基础知识总结----类的进阶知识点
- C语言 输入n,分别用*输出边长为n的实心菱形和空心菱形
- 黑马程序员-----------C语言基础-----------C语言实战(C语言版通讯录)
- C++带模板结构体 类型重定义*
- C++的6种位运算符
- C++容器deque
- C++容器比较
- C语言预处理那些事
- C++库调用C#的回调函数异常退出解决
- C语言实现封装、继承和多态
- C++中的虚函数
- 【C++】单例模式