深度搜索之蒜头学算术
2015-07-14 22:35
218 查看
蒜头的数学实在是太差了,于是老师把他关到小黑屋让他闭门修炼。老师跟他一张纸,上面一排写着1, 2, 3...N这N个数,中间用空白分隔。老师让他在空白处填上加号或者减号。他让蒜头君求出一共有多少种加运算符的方法使得整个表达式的值为0,并输出所有的方案。比如N=7时,1
2 3 4 5 6 7排成一排,一种插入符号的方案为1+2-3+4-5-6+7=0。是不是很有趣,快来帮蒜头君解出这题吧(*´▽`)ノノ
输入为一行,包含一个整数N(3≤N≤9)。
输出为所有在每对数字间插入“+”或“-”后能得到和为零的数列,并按照字典(ASCII码)序排列。如果无解就输出一行None。
不知道字典序和ASCII也不要紧,我们看样例输出就清楚啦,1到N排成一排,先每个位置优先放"+",再放"-",这么放的原因是因为"+"的ASCII码要比"-"小。
2 3 4 5 6 7排成一排,一种插入符号的方案为1+2-3+4-5-6+7=0。是不是很有趣,快来帮蒜头君解出这题吧(*´▽`)ノノ
输入为一行,包含一个整数N(3≤N≤9)。
输出为所有在每对数字间插入“+”或“-”后能得到和为零的数列,并按照字典(ASCII码)序排列。如果无解就输出一行None。
不知道字典序和ASCII也不要紧,我们看样例输出就清楚啦,1到N排成一排,先每个位置优先放"+",再放"-",这么放的原因是因为"+"的ASCII码要比"-"小。
#include <iostream> #include <cstdio> using namespace std; int n; // 保存读入的整数N bool opr[10]; // 可以用一个bool数组保存所有n-1个符号,我们用true表示加号"+",用false表示减号"-"。 bool found = false; // 表示是否找到一组解,如果没找到的话需要在最后输出"None" // dfs函数,保存两个状态:deep表示递归深度,就是枚举到第几个数字左边的符号;sum表示之前部分表达式的值。 // 如果枚举完成后sum的值刚好为0,则输出这组方案。我们需要在搜索的过程中用opr数组保存状态。 void dfs(int deep, int sum) { // 请在下面的条件表达式中填上对应的值。 if (deep == n) { if (sum == 0) { found = true; for(int i = 1; i <= n; i++) { printf("%d", i); if(i == n) break; if(opr[i]) printf("+"); else printf("-"); } printf("\n"); } return ; } opr[deep] = true; dfs(deep + 1, sum + deep + 1); opr[deep] = false; dfs(deep + 1, sum - deep - 1); } int main() { while(scanf("%d", &n) != EOF) { found = false; dfs(1, 1); if(found == false) printf("None\n"); } return 0; }
相关文章推荐
- Project Euler:Problem 64 Odd period square roots
- 为什么重装win8.1后自动弹出安装360
- 使用gazebo实现turtlebot入门级开发
- 【工业串口和网络软件通讯平台(SuperIO)教程】一.通讯机制
- java比较日期大小及日期与字符串的转换【SimpleDateFormat操作实例】
- 下拉弹出列表选择项效果
- java比较日期大小及日期与字符串的转换【SimpleDateFormat操作实例】
- 单点登录(一)使用Cookie+File实现单点登录
- Ps常用快捷键
- 【工业串口和网络软件通讯平台(SuperIO)教程】一.通讯机制
- WIN10系统32,64位系统自动激活版
- 立方和等式
- 互联网搜索广告介绍(二)
- 菜鸟学习c++—实现简单的冒泡排序和插入排序算法
- 如何提高利用视频学习的学习效率—— Swift
- WordPress详细安全设置
- officetohtml
- 【剑指offer】和为S的连续整数序列
- 哈工大操作系统实验3—进程管理
- 黑马程序员----集合框架工具类,几个新特性