Lizard Era: Beginning

news2024/12/25 22:32:52

题目

在这里插入图片描述

思路

暴力dfs会TLE,考虑折半搜索
将每次任务分为左边获得的和右边获得的
l 1 + r 1 = l 2 + r 2 = l 3 + r + 3 l_1+r_1=l_2+r_2=l_3+r+3 l1+r1=l2+r2=l3+r+3
为了让左边搜索时只依赖l,右边只依赖r,所以移项变为
r 1 − r 2 = l 2 − l 1 r_1-r_2=l_2-l_1 r1r2=l2l1, r 1 − r 3 = l 3 − l 1 r_1-r_3=l_3-l_1 r1r3=l3l1
先搜左边,将所得的 l 2 − l 1 l_2-l_1 l2l1 l 3 − l 1 l_3-l_1 l3l1存入pair中作为key在map中指向结构体tmp
tmp存得到这个pair的步骤(xu数组)和 l 1 l_1 l1
为了让 l 1 l_1 l1尽可能大,我们在更新时只存 l 1 l_1 l1较大的tmp

代码

#include<bits/stdc++.h>
using namespace std;
const int maxn=30;
int n;
int a[maxn],b[maxn],c[maxn];
int opt[maxn],now[maxn];
char ANS[][3]={"xx","LM","MW","LW"};
struct node{
	int xu[maxn];
	int l1;
	node() { l1=0;memset(xu,0,sizeof(xu)); }
};
map<pair<int,int>,node> mp;
int ans=-1e9;
void cpy(int *a,int *b,int st,int en) { for(int i=st;i<=en;i++) a[i]=b[i]; }
void dfs1(int i,int l1,int l2,int l3){
	if(i==n/2+1){
		int a1=l2-l1,a2=l3-l1;
		pair<int,int> t=make_pair(a1,a2);
		if(mp.count(t)&&mp[t].l1>l1) return;
		node tmp;tmp.l1=l1;
		cpy(tmp.xu,now,1,n/2);//前半部分的步骤
		mp[t]=tmp;
		return;
	}
	//模拟三种情况
	now[i]=1,dfs1(i+1,l1+a[i],l2+b[i],l3);
	now[i]=2,dfs1(i+1,l1,l2+b[i],l3+c[i]);
	now[i]=3,dfs1(i+1,l1+a[i],l2,l3+c[i]);
}
void dfs2(int i,int r1,int r2,int r3){
	if(i==n+1){
		int b1=r1-r2,b2=r1-r3;
		pair<int,int> t=make_pair(b1,b2);
		if(!mp.count(t)) return;
		if(mp[t].l1+r1>ans) cpy(opt,mp[t].xu,1,n/2),cpy(opt,now,n/2+1,n),ans=mp[t].l1+r1;
		return;
	}
	now[i]=1,dfs2(i+1,r1+a[i],r2+b[i],r3);
	now[i]=2,dfs2(i+1,r1,r2+b[i],r3+c[i]);
	now[i]=3,dfs2(i+1,r1+a[i],r2,r3+c[i]);
}
int main()
{
	cin>>n;
	for(int i=1;i<=n;i++) cin>>a[i]>>b[i]>>c[i];
	dfs1(1,0,0,0),dfs2(n/2+1,0,0,0);
	if(ans==-1e9) { cout<<"Impossible";return 0; }
	for(int i=1;i<=n;i++) cout<<ANS[opt[i]]<<endl;
	return 0;
}

end

完结撒花

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

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

相关文章

b 树和 b+树的理解

项目场景&#xff1a; 图灵奖获得者&#xff08;Niklaus Wirth &#xff09;说过&#xff1a; 程序 数据结构 算法&#xff0c; 也就说我们无时无刻 都在和数据结构打交道。 只是作为 Java 开发&#xff0c;由于技术体系的成熟度较高&#xff0c;使得大部分人认为&#xff1…

BugKu CTF(杂项篇MISC)—社工-进阶收集

BugKu CTF(杂项篇MISC)—社工-进阶收集 提 示: flag{小美小区名字拼音} 描 述: 小明当年为了追求小美想尽办法获得小美的地址。直到有一天小美发了一条说说&#xff0c;小明觉得希望来了。(实战改编题&#xff0c;难度降低了。) [外链图片转存失败,源站可能有防盗链机制,建议…

CAS 机制

问题分析与思考&#xff1a; CAS 是 Java 中 Unsafe 类里面的方法&#xff0c;它的全称是 CompareAndSwap&#xff0c;比较并交换 的意思。 它的主要功能是能够保证在多线程环境下&#xff0c;对于共享变量的修改的原子性。 举个例子&#xff0c;比如说有这样一个场景&#xff…

手机上怎么pdf转word?教你这样操作

手机上怎么pdf转word&#xff1f;在现代社会&#xff0c;PDF和Word文档是我们工作和学习中经常用到的文档格式。有时候&#xff0c;我们需要将PDF文档转换为Word文档&#xff0c;以便更好地编辑和修改。那么&#xff0c;我们该如何在手机上实现PDF转Word呢&#xff1f;今天就给…

从小白到大神之路之学习运维第71天-------Docker容器引擎操作(创建私有仓库、docker资源限制、数据持久化、volume的基本使用)

第四阶段 时 间&#xff1a;2023年8月1日 参加人&#xff1a;全班人员 内 容&#xff1a; Docker容器引擎操作 目录 一、Docker 容器操作 1、创建容器与运行容器 2、容器的启动与停止 3、容器的运行与终止 4、容器的进入 5、容器的导出与导入 6、容器的删除 7、文…

【C语言】关键字static——static修饰局部变量、全局变量和函数详解!

在C语言中&#xff0c;static是修饰变量和函数的。static修饰局部变量称为静态局部变量&#xff0c;static修饰全局变量称为静态全局变量&#xff0c;static修饰函数称为静态函数。 文章目录 静态变量在静态区分配内存static修饰全局变量static修饰局部变量static修饰函数 静态…

2023Q2纯电汽车销量统计,特斯拉遥遥领先,比亚迪和大众横向对比

根据8月1日的消息&#xff0c;国际科技媒体insideevs最近针对2023年第2季度特斯拉、比亚迪和大众三家电动汽车制造商的纯电动汽车销量做了横向比较。 根据媒体报道&#xff0c;2023年第2季度&#xff0c;三家汽车制造企业的销量都有不同程度的增长&#xff0c;较去年同期和今年…

千云探探监测到7月25日法国巴黎Facebook网络恢复正常

前情回顾&#xff1a;针对法国近期出现的骚乱&#xff0c;法国总统马克龙7月4日表示&#xff0c;如果事态失控&#xff0c;法国政府可能需要监管或关闭社交网络。北京时间2023年7月4日17时45分&#xff0c;埃文科技的千云探探发现法国巴黎地区访问Facebook社交网络的网络时延从…

iPhone 8 Plus透明屏应用范围详解

iPhone 8 Plus是苹果公司于2017年推出的一款智能手机&#xff0c;它采用了全新的玻璃机身设计&#xff0c;支持无线充电&#xff0c;并且搭载了更强大的A11仿生芯片。 而透明屏则是一种新型的屏幕技术&#xff0c;可以使手机屏幕呈现出透明的效果。 透明屏是一种将屏幕背后的元…

网络层:IP协议/Mac协议

IP协议 主机: 配有IP地址, 但是不进行路由控制的设备; 路由器: 即配有IP地址, 又能进行路由控制; 节点: 主机和路由器的统 称; IP 目标网络&#xff08;前半部分&#xff09; 目标主机&#xff08;后半部分&#xff09; IP层的核心&#xff1a;IP地址定位主机&#xff08;定…

MySQL篇

文章目录 一、MySQL-优化1、在MySQL中&#xff0c;如何定位慢查询?2、SQL语句执行很慢, 如何分析呢&#xff1f;3、了解过索引吗&#xff1f;&#xff08;什么是索引&#xff09;4、索引的底层数据结构了解过嘛 ?5、什么是聚簇索引什么是非聚簇索引 ?6、知道什么是回表查询嘛…

安达发|APS智能排程软件推动企业智能转型

随着智能化技术的飞速发展&#xff0c;企业在构建智能计划排产规划方面有了新的可能性。APS排程软件&#xff08;Advanced Planning and Scheduling&#xff09;作为一种强大的工具&#xff0c;为企业提供了实现智能计划排产规划的新模式&#xff0c;主要是利用计算机运算速度快…

面向对象程序三大特性一:封装(超详细)

目录 目录 封装 1.1访问限定符 1.2封装介绍 1.3封装的实现步骤 (三步) 总结 封装 1.1访问限定符 Java 中主要通过类和访问权限来实现封装&#xff1a; 类可以将数据以及封装数据的方法结合在一起&#xff0c;&#xff0c;而访问权限用来控制方法或者字段能否直接在类…

linux驱动定时器实现按键按下打印字符

#include <linux/init.h> #include <linux/module.h> #include <linux/of.h> #include <linux/of_irq.h> #include <linux/interrupt.h>struct device_node *dev; unsigned int irqno; //中断处理函数 irqreturn_t myirq_handler(int irq,void *…

后端整理(集合框架、IO流、多线程)

1. 集合框架 Java集合类主要有两个根接口Collection和Map派生出来 Collection派生两个子接口 List List代表了有序可重复集合&#xff0c;可以直接根据元素的索引进行访问Set Set代表无序不可重复集合&#xff0c;只能根据元素本身进行访问 Map接口派生 Map代表的是存储key…

Vue2面试题

1. Vue 的基本原理 当 一 个 Vue 实 例 创 建 时 &#xff0c; Vue 会 遍 历 data 中 的 属 性 &#xff0c; 用 Object.defineProperty &#xff08; vue3.0 使 用 proxy&#xff09; 将 它 们 转 为 getter/setter&#xff0c;并且在内部追踪相关依赖&#xff0c;在属性被访…

linux系统中详细分析MMU的具体实现

先来看一张图 ​第一&#xff1a;MMU内存管理 MMU&#xff08;Memory Management Unit&#xff0c;内存管理单元&#xff09;是一种硬件模块&#xff0c;用于在CPU和内存之间实现虚拟内存管理。 其主要功能是将虚拟地址转换为物理地址&#xff0c;同时提供访问权限的控制和缓存…

控制反转ioc理解,配置说明

先写个例子吧 配置文件&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <beans xmlns"http://www.springframework.org/schema/beans"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"h…

价值 1k 嵌入式面试题-单片机 main 函数之前都做了啥?

开门见山 请说下单片机&#xff08;Arm&#xff09;在运行到 main() 函数前&#xff0c;都做了哪些工作&#xff1f; 常见问题 系统初始化工作&#xff0c;太泛泛硬件初始化&#xff0c;比较不具体 答题思路 这道题应该从两方面回答&#xff0c;一个是比较表面的硬件的初始化…

leetcode(力扣) 剑指 Offer 12. 矩阵中的路径(回溯 DFS)

文章目录 题目描述思路分析完整代码 题目描述 给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 单词必须按照字母顺序&#xff0c;通过相邻的单元格内的字母构成&#xff…