深度搜索之蒜头学算术
来源:互联网 发布:java中的类和对象 编辑:程序博客网 时间:2024/04/28 07:36
蒜头的数学实在是太差了,于是老师把他关到小黑屋让他闭门修炼。老师跟他一张纸,上面一排写着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。
输入为一行,包含一个整数N(3≤N≤9)。
输出为所有在每对数字间插入“+”或“-”后能得到和为零的数列,并按照字典(ASCII码)序排列。如果无解就输出一行None。
不知道字典序和ASCII也不要紧,我们看样例输出就清楚啦,1到N排成一排,先每个位置优先放"+",再放"-",这么放的原因是因为"+"的ASCII码要比"-"小。
#include <iostream>#include <cstdio>using namespace std;int n; // 保存读入的整数Nbool 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;}
0 0
- 深度搜索之蒜头学算术
- 【计蒜客】基础算法入门之深度搜索(2)蒜头学算术d
- 蒜头学算术
- (深度优先搜索第二课) 蒜头学算数 - DFS
- 蒜头学算术,计蒜客算法学习记录
- 计蒜客课程系列:蒜头学算术(DFS)
- 计蒜客课程算法—蒜头学算术(DFS)
- 二叉搜索树之蒜头君的新技能
- 计蒜客 蒜头君学英语
- 从零开始学算法(三)搜索算法(一)(深度优先搜索)之地图迷宫
- 蒜头君学代数(二分)
- 蒜头君学英语--set()练习
- 基础算法之“蒜头君买书”
- 迷宫之深度搜索
- 数据结构之深度搜索
- 重学数据结构系列之——图的遍历(广度优先搜索和深度优先搜索)学习来源:计蒜客
- 数据结构之深度优先搜索
- 深度优先搜索之 nkoj2221
- 【工业串口和网络软件通讯平台(SuperIO)教程】一.通讯机制
- OLAP、OLTP的介绍和比较
- java比较日期大小及日期与字符串的转换【SimpleDateFormat操作实例】
- 为什么重装win8.1后自动弹出安装360
- c语言如何在控制台输出%
- 深度搜索之蒜头学算术
- java io相关类的操作(system,scanner,printwriter)
- 使用gazebo实现turtlebot入门级开发
- Project Euler:Problem 64 Odd period square roots
- Linux内核参数 /etc/sysctl.conf 功能说明
- java项目中自定义的properties文件的使用方法
- 立方数之和
- 【LintCode】Rotate String 旋转字符串
- RelativeLayout 位置参数