腾讯面试真题(C语言)

一.题目

求1+2+3+...+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。

二.题目剖析

首先题目要求不能用乘除,那么(首相+末项)*项数/2就不能用,其次不能用循环,最后不能用条件语句,开关语句和条件运算符,那么想要求一个位置长度的数列和就一定要让操作数"动起来",想来想去也就只有递归还能试一试了,但递归要有限制条件,不过这个条件不能用条件语句和条件运算符来表现,那么只能想想其他的逻辑运算符,好像也只有用逻辑运算符的短路特性,才能限制递归。

三.代码实现

cpp 复制代码
static int a = 0;
int fun(int n)
{
	int x = (n) && (fun(n - 1));
	return a += n;;
}
int main()
{
	int n;
	scanf("%d", &n);
	printf("%d", fun(n));
	return 0;
}

四.代码剖析

首先定义一个全局变量a(或者在函数内部定义一个静态变量a),这两种做法都行,目的是为了防止函数在被调用完一次后变量a被初始化,然后利用逻辑与运算短路的特性(如果左操作数为0,将不再计算右操作数),这样如果把递归式放到右操作数,这样如果左操作数为0,递归就会结束。

相关推荐
OKkankan7 分钟前
单链表算法题(数据结构)
c语言·数据结构·数据库·c++·算法
ZZZ_O^O17 分钟前
动态规划-背包问题——[模版]完全背包问题
c++·学习·算法·leetcode·动态规划
Koishi_TvT21 分钟前
蓝桥杯c++算法学习【3】之思维与贪心(重复字符串、翻硬币、乘积最大、皮亚诺曲线距离【难】:::非常典型的必刷例题!!!)
c++·学习·算法·游戏·贪心算法·蓝桥杯·c
t5y221 小时前
【C语言】Union
c语言·开发语言·算法
MATLAB滤波1 小时前
二维、三维情况下的锚点优选方法
算法·matlab·定位
ZZZ_O^O2 小时前
动态规划-背包问题——1049.最后一块石头的重量II
c++·学习·算法·leetcode·动态规划
xisai882 小时前
2025年开考科目有哪些?
java·开发语言·javascript·算法·kotlin
夕水3 小时前
真是惭愧,直到今天,我才搞懂桶排序算法
javascript·算法
yangmc043 小时前
判断子序列
开发语言·数据结构·c++·算法·矩阵·图论
新兴AI民工3 小时前
opencv调用扩展库SIFT算法
opencv·算法·sift·opencv420·xfeature2d库