【算法题】题目:求1+2+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字以及条件判断语句(A?B:C)

版权声明:本文为博主原创文章,未经博主允许不得转载。 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"被短路"


代码:


运行结果:




猜你喜欢

转载自blog.csdn.net/TMT123421/article/details/51613166