P8650 [蓝桥杯 2017 省 A] 正则问题(dfs )

多重括号,利用回溯来对上一层括号中的内容进行反馈

实现:

若为 x 长度加一

若为 ( 进入递归计算 (计算相当于子表达式)

若为 ) 结束当前递归

若为 | 计算递归,并与当前长度进行比较

复制代码
#include<stdio.h>
#include<iostream>
using namespace std;
int dec1();
int main()
{

	printf("%d", dec1());
	return 0;
}
int dec1()
{
	char ch;
	int len = 0;
	while (cin >> ch)
	{
		if (ch == '(')
			len += dec1();
		else if (ch == 'x')
			len++;
		else if (ch == ')')
			return len;
		else
			return max(len, dec1());
	}
	return len;
}
相关推荐
sali-tec9 分钟前
C# 基于OpenCv的视觉工作流-章81-弯脚检测
图像处理·人工智能·opencv·算法·计算机视觉
kkeeper~11 分钟前
0基础C语言积跬步之自定义类型联合和枚举
c语言·开发语言·算法
昵称好难啊12 分钟前
4.OpenClaw源码解析_路由的概念
人工智能·算法
wanderist.13 分钟前
14决赛蓝桥杯
职场和发展·蓝桥杯
Bingorl16 分钟前
机器学习之KNN算法
人工智能·算法·机器学习
muddjsv18 分钟前
《算法导论》入门学习路径:从零基础到系统掌握
学习·算法
KaMeidebaby36 分钟前
卡梅德生物技术快报|组蛋白乙酰化修饰调控动脉粥样硬化的分子机制及中药表观干预研究
网络·人工智能·网络协议·tcp/ip·算法
Fms_Sa36 分钟前
分治法—最大子段问题
算法·c#
Galerkin码农选手41 分钟前
awq_marlin和gptq_marlin量化算法简要介绍
算法
buhuizhiyuci41 分钟前
【算法篇】动态规划——斐波那契数列模型
算法·动态规划