【题】每日一题

一.零的数列

描述

  • 请考虑一个由 1 到 N 的数字组成的递增数列:1,2,3,...,N。
  • 现在请在数列中插入 + 表示加,或者 - 表示减, (空格) 表示空白(例如 1-2 3 就等于 1-23),来将每一对数字组合在一起(请不要在第一个数字前插入符号)。
  • 计算该表达式的结果并判断其值是否为 0。 请你写一个程序找出所有产生和为零的长度为N的数列。

样例

思路

  • 观察到输入一个数字N时,得到的数列有7个数字6个符号(可使用char数组存储符号),且数字递增。每一组数据的整数不变,变的只有符号,因此返回时可以使用string类型
  • 考虑极端情况下,每个符号都是空格(" "),则有输出:1 2 3 4 5 6 7,于是返回的sum是1234567,注意到12 = 1+2*10,123 = 12+3*10,于是可用深度优先遍历解决。
  • dfs传入的参数需要有:int整数(从1开始递增),该条件下的number,符号,sum值
  • 递归出口:当int整数为N,如果sum==0,使用string类型输出结果

代码

cpp 复制代码
using namespace std;
char op[10];
int N;
void dfs(int pos, int num, int sign, int sum)
{
	if (pos == N)
	{
		sum += num * sign;
		if (sum == 0)
		{
			string s = "1";
			for (int i = 1; i < N; i++)
			{
				s += op[i];
				s += to_string(i+1);
			}
			cout << s << endl;
		}
		return;
	}
	//空格
	op[pos] = ' ';
	dfs(pos + 1, num * 10 + (pos + 1), sign, sum);
	//加号
	op[pos] = '+';
	dfs(pos + 1, pos + 1, 1, sum + num * sign);
	//减号
	op[pos] = '-';
	dfs(pos + 1, pos + 1, -1, sum + num * sign);
}
int main()
{
	cin >> N;
	dfs(1, 1, 1, 0);
}

注意:空格递归时传入的sign,一层递归结束时保留原有的sign


相关推荐
重生之我是Java开发战士9 小时前
【动态规划】简单多状态dp问题:按摩师,打家劫舍,删除并获得点数,粉刷房子,买卖股票的最佳时机
算法·动态规划·哈希算法
KAU的云实验台10 小时前
单/多UAV、静/动态路径规划,基于PlatEMO平台的带约束多目标优化 本文核心内容:
算法·matlab·无人机
Liangwei Lin10 小时前
洛谷 P1807 最长路
数据结构·算法
会编程的土豆10 小时前
【数据结构与算法】二叉树从建立开始
数据结构·c++·算法
_日拱一卒10 小时前
LeetCode:最大子数组和
数据结构·算法·leetcode
计算机安禾11 小时前
【数据结构与算法】第22篇:线索二叉树(Threaded Binary Tree)
c语言·开发语言·数据结构·学习·算法·链表·visual studio code
算法鑫探11 小时前
解密2025数字密码:数位统计之谜
c语言·数据结构·算法·新人首发
计算机安禾11 小时前
【数据结构与算法】第21篇:二叉树遍历的经典问题:由遍历序列重构二叉树
c语言·数据结构·学习·算法·重构·visual studio code·visual studio
信奥胡老师11 小时前
P1255 数楼梯
开发语言·数据结构·c++·学习·算法
爱睡懒觉的焦糖玛奇朵12 小时前
【工业级落地算法之人员摔倒检测算法详解】
人工智能·python·深度学习·神经网络·算法·yolo·目标检测