我用递归写单调栈(?)

news2024/12/25 22:20:40

在这里插入图片描述
前言:嗯,这个题上午有的思路,敲了一中午代码,改了一下午最后超时?
:D. Boris and His Amazing Haircut
题意:一个理发师可以把一段数组给建成一个高度,他现在每个高度的剪子都有若干个。给一个原始数组和目标数组,问能不能剪成目标数组。
奇怪的想法: 理发师最优的剪法就是先剪出来高的,然后在高的头发形成的段之间再剪次高的。直接上分治,结果超时,边界控制太难写了,
超时的代码

#include<iostream>
#include<cstdio>
#include<vector>
#include<map>
#include<algorithm>
using namespace std;
const int length = 2e5 + 5;
vector<int> ag;
vector<int> bg;
map<int,int> mp;
vector<int> count1;
vector<vector<int>> index1;
int tree[length << 3];
void update(int l, int r, int L, int R, int cnt, int v)
{
	if (L >= l && R <= r)
	{
		tree[cnt] = v;
		return;
	}
	if (L > r || R < l)
	{
		return;
	}
	int mid = (L + R) / 2;
	update(l, r, L, mid, cnt << 1, v);
	update(l, r, mid + 1, R, cnt * 2 + 1, v);
	tree[cnt] = max(tree[cnt * 2], tree[cnt * 2 + 1]);
}
int query(int l, int r, int L, int R, int cnt)
{
	if (L>=l&&R<=r)
	{
		return tree[cnt];
	}
	if (L > r || R < l)
		return 0;
	int mid = (L + R) / 2;
	int a = query(l, r, L, mid, cnt * 2);
	int b = query(l, r, mid + 1, R, cnt * 2 + 1);
	return max(a, b);
}
int n1;
bool DP(int l, int r)
{
	//if()
	if (l > r)
		return 1;
	int yh = query(l, r, 0, n1 - 1, 1);
	bool sum = 1;
	int lflag = ((l==0)?0:1);
	int rflag = ((r==n1-1)?0:-1);
	int cut = 0;
	//找到第一个大于等于l的数
	int a = -1;
	int b = index1[yh].size();
	while (a != b - 1)
	{
		int mid = (a + b) / 2;
		if (index1[yh][mid] < l)
			a = mid;
		else
			b = mid;
	}
	int i = b;
	int in = 0;
	for (; i<index1[yh].size()&&index1[yh][i]<=r; i++)
	{
		if (i != index1[yh].size() && mp[ag[index1[yh][i]]] != mp[bg[index1[yh][i]]]&&cut==0)
		{
			cut = 1;
			if (count1[mp[bg[index1[yh][i]]]])
				count1[mp[bg[index1[yh][i]]]]--;
			else
				return 0;
		}
		if (in == 0)
		{
			bool a=DP(l , index1[yh][i] - 1);
			sum = sum & a;
		}
		else
		{
			bool a = DP(index1[yh][i - 1] + 1, index1[yh][i] - 1);
			sum = sum & a;
		}
		if (sum == 0)
			return sum;
		in = 1;
	}
	if (i!=index1[yh].size()&&index1[yh][i] > r)
	{
		if (i != 0)
		{
			bool a = DP(index1[yh][i - 1] + 1, r);
			sum = sum & a;
		}
	}
	else if (i == index1[yh].size() && index1[yh][i - 1] != r)
	{
		bool a = DP(index1[yh][i - 1] + 1, r);
		sum = sum & a;
	}
	return sum;
}
int main(void)
{
	int t;
	scanf_s("%d", &t);
	for (int i = 0; i < t; i++)
	{
		int n;
		scanf_s("%d", &n);
		n1 = n;
		vector<int> a(n,0);
		for (int i = 0; i < n; i++)
		{
			scanf_s("%d", &a[i]);
		}
		vector<int> b(n, 0);
		for (int i = 0; i < n; i++)
		{
			scanf_s("%d", &b[i]);
		}
		int m;
		scanf_s("%d", &m);
		vector<int> c(m, 0);
		for (int i = 0; i < m; i++)
		{
			scanf_s("%d", &c[i]);
		}
		ag = a; bg = b;//全局变量赋值
		vector<int> tmp=b;
		sort(tmp.begin(), tmp.end());
		vector<int>::iterator p = unique(tmp.begin(), tmp.end());
		int off = p - tmp.begin();
		map<int, int> hk;
		int cnt = 1;
		for (int i = 0; i < off; i++)
		{
			hk[tmp[i]] = i + 1;
		}
		mp = hk;
		vector<int> tmp_count(length);
		for (int i = 0; i < m; i++)
		{
			tmp_count[mp[c[i]]]++;//统计映射之后的数量
		}
		count1 = tmp_count;
		memset(tree, 0, sizeof(tree));
		vector<vector<int>> edge(length);
		int ok = 1;
		for (int i = 0; i < n; i++)
		{
			if (a[i] < b[i])
				ok = 0;
			update(i, i, 0, n - 1, 1, mp[b[i]]);//更新区间最值以及坐标位置
			edge[mp[b[i]]].push_back(i);
		}
		if (ok == 0)
		{
			printf("NO\n");
			continue;
		}
		index1 = edge;
		int yh=DP(0, n - 1);
		if (yh)
			printf("YES\n");
		else
			printf("NO\n");
	}
}

正解
思考源头:为啥要剪一段?省剪子啊,他的剪子都是一次性的,用完不能再用乐。并且剪成高度为 5 5 5的时候不能穿过高度为 8 8 8的。所以就用单调栈呗,注意 a [ i ] = = b [ i ] a[i]==b[i] a[i]==b[i]的头发可以弹出数,但是不能入栈,入栈的目的就是不让两边相同高度的头发剪两次。但是 a [ i ] = = b [ i ] a[i]==b[i] a[i]==b[i]的可以作为山丘的两端,高度低的不能穿过他。
A C AC AC代码

#include<iostream>
#include<cstdio>
#include<map>
#include<stack>
using namespace std;
const int length = 2e5 + 5;
int a[length];
int b[length];
map<int, int> mp;
int main(void)
{
	int t;
	scanf_s("%d", &t);
	for (int i = 0; i < t; i++)
	{
		mp.clear();
		int n;
		scanf_s("%d", &n);
		for (int i = 0; i < n; i++)
		{
			scanf_s("%d", &a[i]);
		}
		for (int i = 0; i < n; i++)
		{
			scanf_s("%d", &b[i]);
		}
		int m;
		scanf_s("%d", &m);
		for (int i = 0; i < m; i++)
		{
			int a;
			scanf_s("%d", &a);
			mp[a]++;
		}
		int flag = 1;
		stack<int> s;
		for (int i = 0; i < n; i++)
		{
			if (a[i] < b[i])
			{
				flag = 0;
				break;
			}
			while (!s.empty() && s.top() < b[i])
				s.pop();
			if ((s.empty() || s.top() > b[i])&&a[i]!=b[i])
			{
				s.push(b[i]);
				if (mp[b[i]] == 0)
				{
					flag = 0;
					break;
				}
				mp[b[i]]--;
				
			}
		}
		if (flag == 0)
		{
			printf("NO\n");
		}
		else
			printf("YES\n");
	}
}

还有就是这个题的数值太大了,本来想用离散化的,但是如果能用 m a p map map的话直接用 m a p map map吧, n n n是够的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/168587.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

STL - Set容器

基本概念 构造和赋值 功能描述&#xff1a;创建set容器以及赋值 #include <algorithm> //算法 #include <iostream> #include <set> #include <string> using namespace std;// set/multiset容器void printSet(set<int>& s) {for (set<i…

Java之节点流和处理流(Buffered字节字符处理流)

文章目录前言基本介绍Buffered字符处理流BufferedReader缓冲字符输入流BufferedWriter缓冲字符输出流文件拷贝Buffered字节处理流文件拷贝&#xff08;二进制文件&#xff09;处理流关闭问题前言 Java中的流按照功能可以分为节点流和处理流。其中节点流是直接用来访问数据源&a…

GO的interface的使用和反射

博客主页&#xff1a;&#x1f3c6;看看是李XX还是李歘歘 &#x1f3c6; &#x1f33a;每天不定期分享一些包括但不限于计算机基础、算法、后端开发相关的知识点&#xff0c;以及职场小菜鸡的生活。&#x1f33a; &#x1f497;点关注不迷路&#xff0c;总有一些&#x1f4d6;知…

自动化测试

一、关于自动化什么是自动化?扫地机器人 自动浇水机 自动洗手液 智能马桶... &#xff0c;能够有效的减少人力的消耗&#xff0c;同时提高生活质量。而自动化测试同样&#xff0c;能够有效减少人力的投入&#xff0c;同时提高了测试的质量和效率。回归测试&#xff0c;版本越来…

23.Isaac教程--Isaac导航

Isaac导航 ISAAC教程合集地址: https://blog.csdn.net/kunhe0512/category_12163211.html 节点和消息 Isaac 应用程序由多个节点创建。 导航堆栈具有以下节点&#xff1a; GlobalLocalization&#xff1a;在没有先验信息的情况下&#xff0c;仅使用当前范围扫描测量来估计地…

【JavaGuide面试总结】MySQL篇·上

【JavaGuide面试总结】MySQL篇上1.SQL语句在MySQL中的执行过程MySQL架构Server 层基本组件介绍查询语句分析更新语句分析总结2.MySQL更新语句为什么要用两个日志模块&#xff0c;用一个日志模块不行吗?3.MySQL 支持哪些存储引擎&#xff1f;默认使用哪个&#xff1f;4.MySQL 存…

虹科分享 | TSN时间敏感网络测试框架

一、时间敏感网络 时间敏感网络&#xff08;TSN&#xff09;允许合并OT和IT世界&#xff0c;并保证确定性以太网网络中所有设备的互操作性和标准化。TSN建立在一个真正成熟的生态系统中&#xff08;如以太网&#xff09;&#xff0c;因此大家认为TSN将是下一代工业网络通信的核…

top命令详解

1. 命令参数 d : 监控内容刷新的时间间隔。 n : 限定监控内容刷新的次数&#xff0c;完成后将会退出 top 视图。 p : 只监控指定PID的进程。 -b : 以非交互非全屏模式运行&#xff0c;一般配合-n指定输出几次统计信息&#xff0c;将输出重定向到指定文件&#xff0c;比如 top …

二分查找----C/C++

目录 1. 二分查找的概念 2. 整数的二分 2.1 二分的模版一 2.2 二分的模版二 2.3. 案例剖析 2.4.整数二分总结 3. 浮点数的二分 1. 二分查找的概念 折半查找(BinarySearch)技术&#xff0c;又称为二分查找。它的前提是线性表中的记录 必须是关键码有序(通常从小到大有序)&a…

mysql 分库分表、 分区(partition)、sharding-sphere 综合整理

引言&#xff1a; 一般情况下&#xff0c;如果单表数据量超过2000w的样子查询速度会很慢&#xff0c;因为内存无法存储其索引&#xff0c;使得之后的 SQL 查询会产生磁盘 IO&#xff0c;从而导致性能下降。解决方案&#xff1a;mysql 分区 、 分表处理 分库分表&#xff1a; 原…

【匠心打造】从0打造uniapp 可视化拖拽设计 c_o 第六篇

1、这个版本的变化是左侧增加了布局设计和包资源管理器 包资源管理器&#xff1a;eclipse的特称&#xff0c;左侧的项目管理。和hbuildx左侧类似 项目的整体设计结构如下: v1.0 普通模式&#xff1a;支持新建前端项目&#xff0c;拖拽&#xff0c;且生成前端项目&#xff08…

基于“遥感+”蓝碳储量估算、红树林信息提取实践技术应用与科研论文写作

目录 “遥感”助推蓝碳生态系统碳储量调查简介 第一章 高光谱遥感数据介绍及预处理 第二章 光谱特征分析与参量提取 第三章 高光谱遥感数据分类与制图 第四章 GEE数据处理介绍 第五章 碳储量时空变化与预测 大气温室气体浓度不断增加&#xff0c;导致气候变暖加剧&#x…

DFS的树上应用

目录 一、前言 二、树上的DFS 1、树的重心 2、树的重心例题 3、树的直径 4、树的直径例题 &#xff08;1&#xff09;做两次DFS 三、拓扑排序与DFS 1、用DFS解拓扑排序 2、欧拉路与DFS 3、用DFS输出一个欧拉回路 一、前言 本文主要讲了树上的DFS、树的重心、树的直…

538. 把二叉搜索树转换为累加树

538. 把二叉搜索树转换为累加树 难度中等 给出二叉 搜索 树的根节点&#xff0c;该树的节点值各不相同&#xff0c;请你将其转换为累加树&#xff08;Greater Sum Tree&#xff09;&#xff0c;使每个节点 node 的新值等于原树中大于或等于 node.val 的值之和。 提醒一下&am…

关于浮点数使用的两个注意事项(C/C++)

目录 一.回顾浮点数的存储与读取 二.浮点数使用的第一个注意事项 三.浮点数使用的第二个注意事项 附&#xff1a; 观察内存中的FLT_MAX和FLT_MIN 一.回顾浮点数的存储与读取 http://t.csdn.cn/oVwte 浮点数的存入与读取流程总览&#xff1a; 二.浮点数使用的第一个注意事…

理解实现八大排序

目录 一、初步认识 二、直接插入排序 三、希尔排序 四、直接选择排序 五、堆排序 六、冒泡排序 七、快速排序 7.1 Hoare版本 7.2 挖坑法 7.3 前后指针法 7.4 非递归 7.5 优化方法 7.5.1 三数取中 7.5.2 小区间优化 八、归并排序 九、计数排序 一、初步认识 排…

Netty入门

二. Netty 入门 1. 概述 1.1 Netty 是什么&#xff1f; Netty is an asynchronous event-driven network application framework for rapid development of maintainable high performance protocol servers & clients.Netty 是一个异步的、基于事件驱动的网络应用框架&…

简单开发网站+HTML标签

目录 一、学习路线 二、快速开发网站 1、简单demo 2、浏览器能识别的标签 ① 编码② Title ③ 标题 ④ div和span ⑤ 超链接 ⑥ 图片⑦ 列表 ⑧ 表格 ⑨ input系列 ⑩ 下拉框 ⑪ 多行文本 三、网络请求 四、案例 1、用户注册 2、用户登录 五、小结 1、学习标签的总…

网易互客CRM 微盟系统 管易系统 金蝶系统对接集成整体解决方案

前言&#xff1a;大部分的企业都可能只用一套系统组织架构复杂&#xff0c;业务流程繁琐&#xff0c;内部同时有CRM系统、OMS系统、ERP系统......且各个系统都需要独立登陆&#xff0c;造成IT部门数据监管困难&#xff01;如何在同一套中台系统上关联多管理系统呢&#xff1f;系…

【GD32F427开发板试用】-03-定时器1 的不算坑的坑和时钟设置

本篇文章来自极术社区与兆易创新组织的GD32F427开发板评测活动&#xff0c;更多开发板试用活动请关注极术社区网站。作者&#xff1a;申小林 先说一下我使用定时器1 的时候吧&#xff0c;最开始我以为定时器1是挂在APB1上的&#xff0c;随意按照惯性思维&#xff0c;定时器的时…