【编程题目】求1+2+…+n, 要求不能使用乘除法、for、while、if、else、switch、case和条件语句
看到这个问题,第一个反应是真变态啊。 然后,直觉是不能用循环就只能用递归了。可递归怎么跳出来却遇到了麻烦, 我连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+2+...+n(函数指针) 代码(C++)
求1+2+...+n(函数指针) 代码(C++) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 求1+2+...+n, 要求不能使用乘除法\for\whi ...
- 编程算法 - 求1+2+...+n(构造函数) 代码(C++)
求1+2+...+n(构造函数) 代码(C++) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 求1+2+...+n, 要求不能使用乘除法\for\whi ...
- 编程算法 - 求1+2+...+n(函数继承) 代码(C++)
求1+2+...+n(函数继承) 代码(C++) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 求1+2+...+n, 要求不能使用乘除法\for\whi ...
- 编程算法 - 求1+2+...+n(模板类) 代码(C++)
求1+2+...+n(模板类) 代码(C++) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 求1+2+...+n, 要求不能使用乘除法\for\whil ...
- 关于C语言的几个考试编程题目
提交要求:1:邮件名称:学号后三位-题目编号-姓名-期中考试.例如:098-1-沈苗-期中考试2:不用附件提交,直接写邮件,内容包括编程思路(写一段自己对题目的认识.思路.技术细节等).源代码.运行结 ...
- 网易云课堂_C++程序设计入门(下)_期末考试_期末考试在线编程题目
期末考试在线编程题目 返回考试 本次考试题目一共两个,在考试期间可以不限制次数地提交 温馨提示: 1.本次考试属于Online Judge题目,提交后由系统即时判分. 2.学生可以在考试截止时间 ...
- OJ——华为编程题目:输入字符串括号是否匹配
package t0815; /* * 华为编程题目:输入字符串括号是否匹配 * 若都匹配输出为0,否则为1 * 样例输入:Terminal user [name | number (1)] * 样例 ...
- php实现 提取不重复的整数(编程题目能够最快的熟悉函数)
php实现 提取不重复的整数(编程题目能够最快的熟悉函数) 一.总结 一句话总结:编程题目能够最快的熟悉函数. 1.字符串反转函数? 没有str_revserse,有arr_reverse,这里是st ...
- python基础练习题(题目 求输入数字的平方,如果平方运算后小于 50 则退出)
day32 --------------------------------------------------------------- 实例046:打破循环 题目 求输入数字的平方,如果平方运算后 ...
随机推荐
- noip2012 疫情控制
[问题描述] H国有n个城市,这n个城市用n-1条双向道路相互连通构成一棵树,1号城市是首都,也是树中的根节点. H国的首都爆发了一种危害性极高的传染病.当局为了控制疫情,不让疫情扩散到边境城市(叶子 ...
- PHP文件的上传与下载
文件上传: 1.单个与多个文件上传 2.上传表单的属性设置 3.PHP配置文件中相关文件上传的设置 4.PHP处理上传的文件数据 php.ini配置: file_uploads = on; 默认on ...
- CodeForces 55D Beautiful numbers
D. Beautiful numbers time limit per test 4 seconds memory limit per test 256 megabytes input standar ...
- Ubuntu 12 修改当前用户密码:new password is too simple
修改当前登录用户的密码,通常使用如下命令: $ passwd Old password:****** New password:******* Re-enter new password:****** ...
- linux各文件夹的作用
文章转载自:http://www.cnblogs.com/amboyna/archive/2008/02/16/1070474.html 精------------------------------ ...
- linux中diff命令用法
diff 命 令是 linux上非常重要的工具,用于比较文件的内容,特别是比较两个版本不同的文件以找到改动的地方.diff在命令行中打印每一个行的改动.最新版 本的diff还支持二进制文件.diff程 ...
- Unable to locate player settings. bin/Data/settings.xml
Hello guys, so according to the this response: http://stackoverflow.com/a/18302624/5727136 you need ...
- 剑指Offer 左旋转字符串
题目描述 汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果.对于一个给定的字符序列S,请你把其循环左移K位后的序列输出.例如,字符序列S=”abc ...
- ADB连不上,ADB server didn't ACK问题,的解决
adb连接不上虚拟机,即便执行了adb kill-server命令也没用? 如果你的错误信息是,ADB server didn't ACK这样的话,说明5037端口被占用了. 只要找出占用此端口的进程 ...
- windows下vim编辑器,字符编码设置。
在windows下的vim默认字符集修改 之前使用vim编辑器的时候碰到乱码的问题,后来在网上看了记下了:在vim编辑器中按esc进入命令模式 1.修改vim内部编码 set encoding= ...