蒜头学算术
来源:互联网 发布:好看的耽美网络电视剧 编辑:程序博客网 时间:2024/05/17 09:45
蒜头的数学实在是太差了,于是老师把他关到小黑屋让他闭门修炼。老师跟他一张纸,上面一排写着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码要比"-"小。
样例输入
7
样例输出
1+2-3+4-5-6+71+2-3-4+5+6-71-2+3+4-5+6-71-2-3-4-5+6+7#include <bits/stdc++.h>using namespace std;int n;bool opr[10]; //用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 (opr[i]) printf("+"); else printf("-"); } printf("%d\n", n); } //printf("None"); return ; } opr[deep] = true; dfs(deep + 1, sum + deep + 1); opr[deep] = false; dfs(deep + 1, sum - deep - 1) ;}int main() { scanf("%d", &n); dfs(1, 1); if (found == false) printf("None\n"); return 0;}/*这是计蒜客里面的一道搜索练习题*/
0 0
- 蒜头学算术
- 蒜头学算术,计蒜客算法学习记录
- 深度搜索之蒜头学算术
- 计蒜客课程系列:蒜头学算术(DFS)
- 计蒜客课程算法—蒜头学算术(DFS)
- 【计蒜客】基础算法入门之深度搜索(2)蒜头学算术d
- 计蒜客 蒜头君学英语
- 蒜头君学代数(二分)
- 蒜头君学英语--set()练习
- (深度优先搜索第二课) 蒜头学算数 - DFS
- 算法学习——dfs篇——蒜头学算数
- 算术
- 算术
- 蒜头爬楼梯
- 蒜头君的树
- 蒜头君吃桃子
- 蒜头君打老鼠
- 蒜头君的树
- 你可能不知道的 30 个 Python 语言的特点技巧
- 4-3 求链式表的表长 (10分)
- 小聊聊NGUI中Panel的Clip功能(之二)
- 暑假集训 8.3 数据结构 串的操作 sdutoj2463学密码学一定得学程序
- POJ 2485 Highways(最小生成树,树的最大权值边)
- 蒜头学算术
- vim常用的快捷键
- iOS开发 - 第05篇 - 项目 - 04 - OAuth授权 & 首页
- 【转】《10段代码打通 JS 学习的任督二脉》
- 扩展欧几里德(顺带说一下取模)
- POJ:1751 Highways(最小生成树kruskal算法)
- NOIP2010 关押罪犯 解题报告(并查集,补集判断思想)
- 如何理解栈的地址是由高端地址向低端增长?
- switch语句中编程错误:jump to case label