看到这个问题,第一个反应是真变态啊。 然后,直觉是不能用循环就只能用递归了。可递归怎么跳出来却遇到了麻烦, 我连goto语句都考虑了也没弄好。

后来想到一个非常NC的方法:查找表。 如果n限定一个比较小的范围直接用查找表好了。 但题目的目的肯定不是这样的.....

后来,我转换了一下思路 1+2...+n = (n*n + n)>>1  只要求出n*n来就好了, 但问题是不能用乘法,于是硬件出身的我想到了二进制&,|,>>,<<都是可以用的。

思路:设n = 5 则 n = 1 0 1 b.  n * n =

1 0 1

*          1 0 1

--------------------

1 0 1         5

0 0 0

1 0 1                20

---------------------

1 1 0 0 1         25

我们只要把中间那一段的数求出来,加起来就好了。 代码实现中,因为不能写for,我又懒得自己写太多遍加法,于是设定n的取值范围只能是 0-255

/*
题目: 计算 1+2+3+...+n
要求:不可用 乘除 if else for while switch case ?:
*/
#include <stdio.h> const unsigned char b[] = {, <<, <<, <<, <<, <<, <<, <<, <<, <<, <<, <<, <<, <<, <<, <<}; int get_add_factor(unsigned char n, unsigned char onebit)
{
unsigned char b = onebit + (onebit<<) + (onebit<<) + (onebit<<) + (onebit<<) + (onebit<<) + (onebit<<) + (onebit<<);
return n&b;
} int addn(unsigned char n)
{
unsigned char bits[] = {n&b[], (n&b[])>>, (n&b[])>> ,(n&b[])>>, (n&b[])>>, (n&b[])>>, (n&b[])>>, (n&b[])>>}; //把数字的每一位取出来
int tmp[] = {get_add_factor(n, bits[]), get_add_factor(n, bits[])<<, get_add_factor(n, bits[])<<, get_add_factor(n, bits[])<<,
get_add_factor(n, bits[])<<, get_add_factor(n, bits[])<<, get_add_factor(n, bits[])<<, get_add_factor(n, bits[])<<}; int pow = tmp[] + tmp[] + tmp[] + tmp[] + tmp[] + tmp[] + tmp[] + tmp[];
int ans = (pow + n) >> ;
return ans;
} int main()
{
//addn 的输入必须是 0 - 255
int r = addn(); return ;
}

然后,到网上看看别人的答案,我震惊了。原来有这么多种方法啊。

最让我叹服的是下面这个版本: 利用逻辑与&&的特性 成功跳出了循环

#include <stdio.h>
#include <stdlib.h>
#include <string.h> int add_fun(int n, int &sum)
{
n && add_fun(n-, sum); //逻辑与 先计算左边的值 如果 左边的值不为真 则不会计算右边
return (sum+=n);
} int main()
{
int sum=;
int n=; printf("1+2+3+...+n=%d\n",add_fun(n, sum)); return ;
}

方法三:利用类的静态变量 在构造函数中对静态变量做加法 构建多个类对象实现求和

#include <iostream>
using namespace std; class Temp
{
public:
Temp()
{
N++;
SUM+=N;
}
static int GetSum()
{
return SUM;
}
static void Reset()
{
N = ;
SUM = ;
}
~Temp(){};
private:
static int N;
static int SUM;
}; //注意分号 别忘了 //初始化类的静态成员变量
int Temp::N = ;
int Temp::SUM = ; int Sum(int n)
{
Temp::Reset();
Temp * a = new Temp[n];
delete [] a; return Temp::GetSum();
}
int main()
{
int a = Sum();
return ;
}

方法四 利用函数指针.也是非常的巧妙 定义了一个函数指针的数组 只有i = 0的时候 !!i = 0, 其他情况下  !!i = 1 利用这个规则跳出递归

#include <iostream>
using namespace std; typedef int (*fun)(int); int solution_f1(int i)
{
return ;
} int solution_f2(int i)
{
fun f[]={solution_f1, solution_f2};
return i+f[!!i](i-);
} int main()
{
cout<<solution_f2()<<endl;
return ;
}

还有个方法五 利用虚函数的 具体思想其实跟 函数指针很像  这个没仔细看 因为我虚函数学得不好....

#include <iostream>
using namespace std; class A;
A* Array[]; class A
{
public:
virtual int Sum(int n)
{
return ;
}
}; class B:public A
{
public:
virtual int Sum(int n)
{
return Array[!!n]->Sum(n-)+n;
}
}; int solution2_Sum(int n)
{
A a;
B b;
Array[]=&a;
Array[]=&b; int value=Array[]->Sum(n); return value;
} int main()
{
cout<<solution2_Sum()<<endl;
return ;
}

【编程题目】求1+2+…+n, 要求不能使用乘除法、for、while、if、else、switch、case和条件语句的更多相关文章

  1. 编程算法 - 求1+2+...+n(函数指针) 代码(C++)

    求1+2+...+n(函数指针) 代码(C++) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 求1+2+...+n, 要求不能使用乘除法\for\whi ...

  2. 编程算法 - 求1+2+...+n(构造函数) 代码(C++)

    求1+2+...+n(构造函数) 代码(C++) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 求1+2+...+n, 要求不能使用乘除法\for\whi ...

  3. 编程算法 - 求1+2+...+n(函数继承) 代码(C++)

    求1+2+...+n(函数继承) 代码(C++) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 求1+2+...+n, 要求不能使用乘除法\for\whi ...

  4. 编程算法 - 求1+2+...+n(模板类) 代码(C++)

    求1+2+...+n(模板类) 代码(C++) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 求1+2+...+n, 要求不能使用乘除法\for\whil ...

  5. 关于C语言的几个考试编程题目

    提交要求:1:邮件名称:学号后三位-题目编号-姓名-期中考试.例如:098-1-沈苗-期中考试2:不用附件提交,直接写邮件,内容包括编程思路(写一段自己对题目的认识.思路.技术细节等).源代码.运行结 ...

  6. 网易云课堂_C++程序设计入门(下)_期末考试_期末考试在线编程题目

    期末考试在线编程题目 返回考试   本次考试题目一共两个,在考试期间可以不限制次数地提交 温馨提示: 1.本次考试属于Online Judge题目,提交后由系统即时判分. 2.学生可以在考试截止时间 ...

  7. OJ——华为编程题目:输入字符串括号是否匹配

    package t0815; /* * 华为编程题目:输入字符串括号是否匹配 * 若都匹配输出为0,否则为1 * 样例输入:Terminal user [name | number (1)] * 样例 ...

  8. php实现 提取不重复的整数(编程题目能够最快的熟悉函数)

    php实现 提取不重复的整数(编程题目能够最快的熟悉函数) 一.总结 一句话总结:编程题目能够最快的熟悉函数. 1.字符串反转函数? 没有str_revserse,有arr_reverse,这里是st ...

  9. python基础练习题(题目 求输入数字的平方,如果平方运算后小于 50 则退出)

    day32 --------------------------------------------------------------- 实例046:打破循环 题目 求输入数字的平方,如果平方运算后 ...

随机推荐

  1. JS keycode 事件响应

    <script language="javascript"> function keyevent(){ if(event.keyCode==13) alert(&quo ...

  2. 使用Javascript实现返回顶部功能。

    为了提高网站的浏览体验及友好度,相信大部分网站需要一个返回顶部的按钮,如果使用传统的a标记,再做一个div加上链接的话,非常麻烦,不仅每个页面都需要添加,而且不能实现非常智能的效果及简化维护时间. 下 ...

  3. STM32F10xx CAN BUS相关库文件"stm32f10x_can.c"内的库函数解析

    一.背景: 还是继续CAN通信,要节省开发时间,使用库函数可大大降低开发周期,并且还能确保寄存器的配置几 乎是万无一失,所以,在此就STM32F10xx的CAN操作库函数的使用做个简析. STM32有 ...

  4. php 通过curl post发送json数据实例

    例1  代码如下 复制代码 $data = array("name" => "Hagrid", "age" => "3 ...

  5. 【转】MySQL数据类型和常用字段属性总结

    来源:http://www.jb51.net/article/55853.htm 这里先总结数据类型.MySQL中的数据类型大的方面来分,可以分为:日期和时间.数值,以及字符串.下面就分开来进行总结. ...

  6. HDU 5122 K.Bro Sorting(2014北京区域赛现场赛K题 模拟)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5122 解题报告:定义一种排序算法,每一轮可以随机找一个数,把这个数与后面的比这个数小的交换,一直往后判 ...

  7. BZOJ4517——[Sdoi2016]排列计数

    求有多少种长度为 n 的序列 A,满足以下条件: 1 ~ n 这 n 个数在序列中各出现了一次 若第 i 个数 A[i] 的值为 i,则称 i 是稳定的.序列恰好有 m 个数是稳定的 满足条件的序列可 ...

  8. gradle类重复的问题解决方法

    今天遇到一个gradle的类重复问题,学习到一个命令 gradle -q dependencies,可以查看项目里包的依赖关系,发生这个错误是因为我用了一个相册的项目,这个项目里用到了v4包,我自己的 ...

  9. 160809212田京诚C语言程序设计实验2 选择结构程序设计_进阶

    实验2-6 猜数字游戏 实验要求: 编写一个C程序实现一个[1-100]以内的猜数字游戏. (1)       系统随机产生一个[1-100]之间的随机数. (2)       输入任意一个数字.数字 ...

  10. 7.7---找只含3,5,7的数(CC150)

    ----思路:利用三个队列,一个存3,一个存5,一个存7. 然后,3*3的都放第一个.然后3*5,5*5的放第二个.然后,3*7,5*7,7*7的都放第三个. 答案: public static in ...