B. Nastya and Scoreboard(剪枝记忆化搜索)

news2024/10/7 5:29:23

Problem - 1340B - Codeforces

 

Denis,在买了花和糖果之后(你将在下一个任务中了解这个故事),与Nastya约会,向她表白要成为一对。现在,他们坐在咖啡馆里,最后... Denis请她答应在一起,但是... Nastya没有给出任何答案。

因此,这个可怜的男孩非常难过。他非常伤心,以至于用拳头砸了一个带有数字的记分牌。数字显示方式与电子时钟相同:每个数字位置由7个段组成,可以打开或关闭以显示不同的数字。图片展示了如何显示所有10个十进制数字:

打击后,一些段停止工作,也就是说,一些段可能会停止发光,如果它们之前发光的话。但是Denis记得有多少根杆子亮着,现在又有多少根杆子亮着。Denis打破了恰好k个段,他知道哪些杆子现在还能工作。Denis提出了问题:如果你打开恰好k个目前关闭的杆子,最大可能出现在记分牌上的数字是多少?

允许数字包含前导零。

输入

第一行包含整数n(1≤n≤2000)- 记分牌上的数字数量和k(0≤k≤2000)- 停止工作的段数量。

接下来的n行包含长度为7的二进制字符串,其中第i个字符串编码了记分牌上的第i个数字。

记分牌上的每个数字由7个段组成。我们按照下图的方式对它们编号,并假设二进制字符串的第i位如果第i根杆不发光,则为0,如果发光,则为1。因此,长度为7的二进制字符串将指定当前发光的段。

因此,序列“1110111”,“0010010”,“1011101”,“1011011”,“0111010”,“1101011”,“1101111”,“1010010”,“1111111”,“1111011”依次编码从0到9的所有数字。

输出

输出一个由n个数字组成的单个数字 - 如果你打开恰好k根杆子,可以得到的最大数字;如果无法打开恰好k根杆子以显示正确数字,则输出-1。

示例

输入 拷贝

1 7

0000000

输出 拷贝

8

输入 拷贝

2 5

0010010

0010010

输出 拷贝

97

输入 拷贝

3 5

0100001

1001001

1010011

输出 拷贝

-1

注意

在第一个测试中,我们必须包括所有7根杆,并在记分牌上得到一个8。

在第二个测试中,我们打开了一些杆子,以形成数字。对于额外包括的5根杆,可以得到数字07、18、34、43、70、79、81和97,我们选择最大值-97。

在第三个测试中,无法只打开5根杆以显示记分牌上的数字序列。

题解:
首先我们,对于每串数字,可以看他都可以变成什么数字,花费是多少

如果一串数字,无法变成任何0~9的数字,直接输出-1即可(这种情况出现的原因是,原本一个数字那里没有1,但是给出的串上有1)

接着我们可以根据这个花费,从末尾开始往前,记录每个位置的,最大最小花费,便于我们搜索时剪枝

接着从第一位进行搜索,每一位搜索的过程都应该时9~0,

因为贪心来讲,我们如果要结果最大,肯定让前面的数字越大越好,即使他需要消耗的更多,并且这样搜索,会导致第一次搜索成功就是最大值

如果我们搜完恰好用了k次,记得都要返回

搜索过程中,除了根据每个位置我们记录的最大,最小值进行剪枝,还要根据,每个位置的花费看是否成功进行剪枝

#include <cstdio>
#include <cstring>
#include <algorithm>
#include<iostream>
#include<vector>
#include<set>
#include<map>
#include<cmath>
#include<queue>
using namespace std;
typedef long long ll;
 #define int long long
typedef pair<int,int> PII;
typedef unsigned long long ULL;
const int N = 5e5 + 10;
int mod = 1e9 + 7;
int n,k;
int vis[2004][30];
string a[11]={ "1110111", "0010010", "1011101", "1011011", "0111010", "1101011", "1101111", "1010010", "1111111", "1111011" };
int ma[N],mi[N];
int st;
int ans[2004];
int dp[2002][2002];
void dfs(int now,int hua)
{
	if(now == n + 1)
	{
		if(hua == k)
		{
			st = 1;
		}
		return ;
	}
	if(st)
	return ;
	if(dp[now][hua] == -1)
	return ;
	for(int i = 9;i >= 0;i--)
	{
		if(vis[now][i] == -1)
		continue;
		if(hua + vis[now][i] > k)
		continue;
		int els = k - hua - vis[now][i];
		if(els > ma[now + 1])
		continue;
		if(els < mi[now + 1])
		continue;
		ans[now] = i;
		dfs(now + 1,hua + vis[now][i]);
		if(st)
		return ;
		dp[now][hua] = -1;
	}
}
int check(string s,string t)
{
	int w = 0;
	for(int i = 0;i < 7;i++)
	{
		if(s[i] == '1'&&t[i] == '0')
		{
			return -1;
		}
		else if(s[i] != t[i])
		{
			w++;
		}
	}
	return w;
}
void solve()
{
	cin >> n >> k;
	int flag = 0;
	for(int i = 1;i <= n;i++)
	{
		string s;
		cin >> s;
		int f = 0;
		for(int j = 0;j <= 9;j++)
		{
			vis[i][j] = check(s,a[j]);
			if(vis[i][j] != -1)
			{
				f = 1;
			}
		}
		if(!f)
		{
			flag = 1;
		}
	}
	if(flag)
	{
		cout <<"-1\n";
		return ;
	}
	for(int i = n;i >= 1;i--)
	{
		int Max = 0,Min = 1e9;
		for(int j = 0;j <= 9;j++)
		{
			if(vis[i][j] == -1)
			continue;
			Max = max(Max,vis[i][j]);
			Min = min(Min,vis[i][j]);
		}
		ma[i] = ma[i + 1] + Max;
		mi[i] = mi[i + 1] + Min;
	}
	dfs(1,0);
	if(!st)
	{
		cout <<"-1";
		return ;
	}
	for(int i = 1;i <= n;i++)
	{
		cout << ans[i];
	}
}
signed main()
{
	ios::sync_with_stdio(0 );
	cin.tie(0);cout.tie(0);
	int t = 1;
//	cin >> t;
	while(t--)
	{
		solve(); 
	}
}

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

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

相关文章

文盘 Rust -- tokio 绑定 cpu 实践

tokio 是 rust 生态中流行的异步运行时框架。在实际生产中我们如果希望 tokio 应用程序与特定的 cpu core 绑定该怎么处理呢&#xff1f;这次我们来聊聊这个话题。 首先我们先写一段简单的多任务程序。 use tokio::runtime; pub fn main() {let rt runtime::Builder::new_mu…

第48步 深度学习图像识别:RegNet建模(Pytorch)

基于WIN10的64位系统演示 一、写在前面 &#xff08;1&#xff09;RegNet RegNet (Regulated Networks) 是一种由 Facebook AI 的研究者们在 2020 年提出的神经网络架构&#xff0c;旨在探索网络架构设计的各种可能性&#xff0c;并找出最优的网络设计规则。RegNet 的核心理…

vue3ts分离头部变量单独一个ts

这里要说下 博主 vue^3.2.47 typescript^5.0.2 群有小伙伴说之前版本是不支持&#xff0c;所以你对下版本是不是比博主的版本低。 主要是页面代码太多&#xff0c;你看下面 然后博主就想着组合式开发 怎么把页面变干净点&#xff1a; 1、vue的就处理逻辑 2、ts就单纯定义…

vc++ 弹出打开、保存对话框功能(COM组件使用详解)

文章目录 前言一、原理二、代码封装三、使用示例C/C++实战入门到精通 https://blog.csdn.net/weixin_50964512/article/details/125710864 前言 很多应用都会有选择打开文件、或者选择保存文件的功能,这种情况下一般都是弹出一个对话框让用户自己选择。 这并不需要自己…

如何使用Scrum工具进行敏捷项目管理?

敏捷开发是一种轻量级的软件开发方式。 敏捷是一种通过创造变化和响应变化在不确定和混乱的环境中取得成功的能力。 敏捷开发是为了快速响应市场变化、通过自组织、跨职能团队 运用适合他们自身环境的实践进行演进得出解决方案。 所有符合敏捷宣言和敏捷开发十二项原则的方…

单片机要这样保护临界区

目录 一、概述 二、临界区保护测试场景 三、临界区保护三种实现 1、入门做法 2、改进做法 3、终极做法 四、附录---PRIMASK寄存器设置函数在各 IDE 下实现 一、概述 今天给大家分享的是Cortex-M裸机环境下&#xff0c;临界区保护的三种实现。 搞嵌入式玩过 RTOS 的小伙…

程序设计-编程题

CISP-PTE-编程题 2014 #include <iostream> using namespace std;double H(int n,double x) {if (n > 1)return 2 * x*H(n - 1, x) - 2 * (n - 1)*H(n - 2, x);if (n 0)return 1;if (n 1)return 2 * x; }int main() {int n;double x,result;cin >> n;cin >…

torch_geometric安装避坑

总流程&#xff1a; 1. 查看cuda, pytorch, python版本&#xff1b; 2. 依次安装torch_scatter, torch_sparse, torch_cluster, torch_spline&#xff1b; 3. 安装torch_geometric 一. 查看cuda, pytorch, python版本 可选方法如下图&#xff0c;其中该样例的cuda, pytorc…

注意力机制[矩阵]

每一个输入的向量( Embedding后的向量)&#xff0c;均有q,k,v,三个东西。其中q由下图所生成 I矩阵有a1,a2,a3,a4组成&#xff0c;Wq为权重矩阵&#xff0c;将I与Wq相乘求得Q(q1,q2,q3,q4)。K和V与I同理均可求得。 将求得出来的K&#xff0c;转置为竖向量与Q相乘&#xff0c;就…

【UE5 Cesium】12-Cesium for Unreal 去除左下角的icon

问题 在视口左下角的icon如何去除&#xff1f; 解决方法 打开“CesiumCreditSystemBP” 将“Credit Widget Class”一项中的“ScreenCredit”替换为“ScreenCreditWidget” 编译之后icon就不显示了。

戴尔游匣G16 7630原厂Win11系统带F12 Support Assist OS Recevory恢复功能

戴尔游匣G16 7630原厂Win11系统带F12 Support Assist OS Recevory恢复功能 各机型预装系统&#xff0c;带所有dell主题壁纸、dell软件驱动、带戴尔SupportAssist OS Recovery恢复功能&#xff0c;一次性恢复成新机状态&#xff0c;并且以后不用重装系统&#xff0c;直接恢复即…

MVC终极版

MVC终极版 1.把上次的代码打包为架包。2.通过basedao优化代码1.前言 3.后台代码servlet的优化。4前台代码展示 再次优化代码&#xff0c;上两次优化&#xff0c;都不是最完善的&#xff0c;这一次是最完善的了。 1.把上次的代码打包为架包。 选中两个文件&#xff0c;右键然后选…

Unreal 5 Lyra初学者游戏包概览笔记

Lyra初学者游戏包相关的官方视频有两个&#xff1a; Lyra初学者游戏包概览 https://www.bilibili.com/video/BV16B4y197Zy/Lyra跨平台UI开发 https://www.bilibili.com/video/BV1mT4y167Fm/ 这个笔记主要记录的是Lyra初学者包概览笔记的相关内容。里面介绍了如何创建关卡、输…

网络部署的思路

网络部署的思路——网络搭建的步骤 1.拓扑设计——IP地址的规划&#xff08;子网划分&#xff0c;子网汇总&#xff09; 2.实施 2.1 搭建拓扑 2.2 底层——给所有需要配置IP地址的网络节点&#xff0c;配置一个合法的IP地址 2.3 路由——全网可达 2.4 优化 策略——安全方面的…

【Linux初阶】基础IO - FILE结构体中的缓冲区

&#x1f31f;hello&#xff0c;各位读者大大们你们好呀&#x1f31f; &#x1f36d;&#x1f36d;系列专栏&#xff1a;【Linux初阶】 ✒️✒️本篇内容&#xff1a;库函数和系统函数的刷新差异&#xff0c;缓冲区的意义、刷新策略、存在位置、文件写入的逻辑&#xff0c;缓冲…

Unity与iOS交互(1)——需要了解的IOS相关知识

【前言】 以下只是简要介绍&#xff0c;详细的内容需要自己去看链接 【Objective-C基础知识】 .h .m .mm .cpp文件区别 .h是头文件扩展名。头文件包含类&#xff0c;类型&#xff0c;函数和常数的声明&#xff0c;这里的定义一般是Public的 .m是实现文件扩展名。其包含源代…

云环境利用工具-----cf

简介 CF 是一个云环境利用框架&#xff0c;适用于在红队场景中对云上内网进行横向、SRC 场景中对 Access Key 即访问凭证的影响程度进行判定、企业场景中对自己的云上资产进行自检等等。 项目地址&#xff1a;https://github.com/teamssix/cf 使用手册&#xff1a;https://wi…

Java POI excel单元格背景色(填充)、字体颜色(对齐)、边框(颜色)、行高、列宽设置

文章目录 1、Excel Cell单元格背景色颜色名称对照关系2、Excel Cell单元格背景填充样式颜色填充对照关系3、Excel Cell字体样式设置对照图4、Excel 行高、列宽设置5、Excel单元格边框设置边框类型图片对比附一&#xff1a;一些问题1、关于列宽使用磅*20的计算方式2、关于行高使…

常用数据预处理与特征选择方法总结记录

在很多机器学习或者是深度学习建模之前&#xff0c;对于数据的处理尤为重要&#xff0c;选择合适的数据预处理方法和特征构建算法对于后续模型的结果有着很大的影响作用&#xff0c;这里的主要目的就是想记录总结汇总常用到的处理方法&#xff0c;学习备忘&#xff01; 数据清洗…

Docker集群部署-MySQL主从复制

实验目的 利用Docker实现MySQL主从复制架构的部署&#xff0c;实现1主1从集群配置。 实验准备 要求实验主机能够连接外网&#xff0c;已经正确安装Docker&#xff0c;并关闭防火墙和selinux。 【实验步骤】 新建主服务器容器实例3307 # docker run -p 3307:3306 --name my…