【编程题目】求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:打破循环 题目 求输入数字的平方,如果平方运算后 ...
随机推荐
- IOS开发之----NSDictionary,JSON和XML互相转换
本文永久地址为 http://www.cnblogs.com/ChenYilong/p/4044521.html,转载请注明出处. -(void)test { //XML文本范例 ...
- PHP 如何显示大数字,防止显示为 科学计数法 形式
PHP 数字超过一定长度时,会自动转换为 科学计数法 的形式,如 1.2345678912346E+16: 如何 避免转换,让它原样展示呢? 不过,可以用PHP函数 number_format() 来 ...
- 初始Jquery--以及工厂函数
一.JavaScript框架 1什么是JavaScript框架 普通JavaScript的缺点:每种控件的操作方式不统一,不同浏览器下有区别,要编写跨浏览器的程序非常麻烦.因此出现了很多对JavaSc ...
- SQL server 语句新建用户、对用户授权、删除用户实例
Grant select on tb to db_user --给db_user用户授权 tb表 查询权限 一.命令操作 USE mydb GO --1. 新建测试用户 --1.1 添加登录用户和密码 ...
- JAVA设计模式 之 策略模式
一. 定义 设计模式定义了算法族,分别封装起来,让他们之间可以互相替代,此模式让算法的变化独立于使用算法的客户(该定义来自于Head First 设计模式). 二. 应用场景 当我们在应用程序中完成一 ...
- iOS开发——高级篇——地图 MapKit
一.简介 1.在移动互联网时代,移动app能解决用户的很多生活琐事,比如周边:找餐馆.找KTV.找电影院等等导航:根据用户设定的起点和终点,进行路线规划,并指引用户如何到达 在上述应用中,都用到了定位 ...
- [codevs1022]覆盖
[codevs1022]覆盖 试题描述 有一个N×M的单位方格中,其中有些方格是水塘,其他方格是陆地.如果要用1×2的矩阵区覆盖(覆盖过程不容许有任何部分重叠)这个陆地,那么最多可以覆盖多少陆地面积. ...
- javascript中数组concat()join()split()
concat() 方法用于连接两个或多个数组. 该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本. 所以 <script type="text/javascript" ...
- [RouterOS] ROS对接碧海威或PA等流控实现完美流控详细教程(附脚本全免费)
前言: 经常在群里看到不少朋友争论海蜘蛛 ROS 维盟 爱快 碧海威 流控大师 Woyos等等软路由,哪个好.实际上,网络产品是复杂的,现在的软路由功能上已经远远不是单独的路由了.每种产品都有他本身的 ...
- 3.2---最小栈(CC150)
//思路:入栈时不是最小值,永远都没机会成为最小值. import java.util.Stack; class MinStack { private Stack<Integer> sta ...