版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/TMT123421/article/details/51613166
问题:
不小心发现了一道有趣的算法题目,如下:
求1+2+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字以及条件判断语句(A?B:C)
想了一会没想出思路,就百度了一下,然后又不小心发现了大神的解法,甚感奇妙;又给自己打了一通鸡血!
在该题目的要求中,封死了所有简单可行的方法:包括使用数学公式的乘除、循环累加、以及常规判断的条件!确切的说:到最后我是崩溃的!
求解方法:
利用C语言中 && 运算符的短路特性,成功完成了递归判断的结束判断!
逻辑运算的短路特性:
- (表达式1)&&(表达式2) 如果表达式1为假,则表达式2不会进行运算,即表达式2"被短路"
- (表达式1)||(表达式2) 如果表达式1为真,则表达式2不会进行运算,即表达式2"被短路"
代码:
运行结果: