排座椅【详细代码题解】

[NOIP2008 普及组] 排座椅

题目描述

上课的时候总会有一些同学和前后左右的人交头接耳,这是令小学班主任十分头疼的一件事情。不过,班主任小雪发现了一些有趣的现象,当同学们的座次确定下来之后,只有有限的 D D D 对同学上课时会交头接耳。

同学们在教室中坐成了 M M M N N N 列,坐在第 i i i 行第 j j j 列的同学的位置是 ( i , j ) (i,j) (i,j),为了方便同学们进出,在教室中设置了 K K K 条横向的通道, L L L 条纵向的通道。

于是,聪明的小雪想到了一个办法,或许可以减少上课时学生交头接耳的问题:她打算重新摆放桌椅,改变同学们桌椅间通道的位置,因为如果一条通道隔开了 2 2 2 个会交头接耳的同学,那么他们就不会交头接耳了。

请你帮忙给小雪编写一个程序,给出最好的通道划分方案。在该方案下,上课时交头接耳的学生的对数最少。

输入格式

第一行,有 5 5 5 个用空格隔开的整数,分别是 M , N , K , L , D ( 2 ≤ N , M ≤ 1000 , 0 ≤ K < M , 0 ≤ L < N , D ≤ 2000 ) M,N,K,L,D(2 \le N,M \le 1000,0 \le K<M,0 \le L<N,D \le 2000) M,N,K,L,D(2N,M1000,0K<M,0L<N,D2000)

接下来的 D D D 行,每行有 4 4 4 个用空格隔开的整数。第 i i i 行的 4 4 4 个整数 X i , Y i , P i , Q i X_i,Y_i,P_i,Q_i Xi,Yi,Pi,Qi,表示坐在位置 ( X i , Y i ) (X_i,Y_i) (Xi,Yi) ( P i , Q i ) (P_i,Q_i) (Pi,Qi) 的两个同学会交头接耳(输入保证他们前后相邻或者左右相邻)。

输入数据保证最优方案的唯一性。

输出格式

共两行。
第一行包含 K K K 个整数 a 1 , a 2 , … , a K a_1,a_2,\ldots,a_K a1,a2,,aK,表示第 a 1 a_1 a1 行和 a 1 + 1 a_1+1 a1+1 行之间、第 a 2 a_2 a2 行和 a 2 + 1 a_2+1 a2+1 行之间、…、第 a K a_K aK 行和第 a K + 1 a_K+1 aK+1 行之间要开辟通道,其中 a i < a i + 1 a_i< a_{i+1} ai<ai+1,每两个整数之间用空格隔开(行尾没有空格)。

第二行包含 L L L 个整数 b 1 , b 2 , … , b L b_1,b_2,\ldots,b_L b1,b2,,bL,表示第 b 1 b_1 b1 列和 b 1 + 1 b_1+1 b1+1 列之间、第 b 2 b_2 b2 列和 b 2 + 1 b_2+1 b2+1 列之间、…、第 b L b_L bL 列和第 b L + 1 b_L+1 bL+1 列之间要开辟通道,其中 b i < b i + 1 b_i< b_{i+1} bi<bi+1,每两个整数之间用空格隔开(列尾没有空格)。

样例 #1

样例输入 #1

4 5 1 2 3
4 2 4 3
2 3 3 3
2 5 2 4

样例输出 #1

2
2 4

提示

上图中用符号*、※、+标出了 3 3 3 对会交头接耳的学生的位置,图中 3 3 3 条粗线的位置表示通道,图示的通道划分方案是唯一的最佳方案。

题目来源

2008 年普及组第二题(洛谷)

题解

# 读取输入
import sys
input = sys.stdin.read
data = input().split()

# 读取参数
M = int(data[0])
N = int(data[1])
K = int(data[2])
L = int(data[3])
D = int(data[4])

# 初始化每行和每列的干扰计数器
row_interference = [0] * (M + 1)
col_interference = [0] * (N + 1)

index = 5
# 读取每对会交头接耳的同学的位置
for _ in range(D):
    Xi = int(data[index])
    Yi = int(data[index + 1])
    Pi = int(data[index + 2])
    Qi = int(data[index + 3])
    index += 4
    
    if Xi == Pi:
        # 同一行,增加这一列的干扰计数
        col_interference[min(Yi, Qi)] += 1
    else:
        # 同一列,增加这一行的干扰计数
        row_interference[min(Xi, Pi)] += 1

# 按干扰计数排序,选出干扰最大的K行和L列
row_indices = sorted(range(1, M), key=lambda i: -row_interference[i])[:K]
col_indices = sorted(range(1, N), key=lambda i: -col_interference[i])[:L]

# 输出结果
row_indices.sort()
col_indices.sort()

print(" ".join(map(str, row_indices)))
print(" ".join(map(str, col_indices)))

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

(二)前端javascript中的数据结构之栈

栈是一种遵从后进先出&#xff08;LIFO&#xff09;原则的有序集合。新添加的或待删除的元素都保存在栈的 同一端&#xff0c;称作栈顶&#xff0c;另一端就叫栈底。在栈里&#xff0c;新元素都靠近栈顶&#xff0c;旧元素都接近栈底。 栈是限定仅在表的一端进行插入和删除操作…

CnosDB:深入理解时序数据修复函数

CnosDB是一个专注于时序数据处理的数据库。CnosDB针对时序数据的特点设计并实现了三个强大的数据修复函数&#xff1a; timestamp_repair – 对时间戳列进行有效修复&#xff0c;支持插入、删除、不变等操作。value_repair – 对值列进行智能修复&#xff0c;根据时间戳间隔和…

【学习笔记】网络设备(华为交换机)基础知识2——常用设备管理命令

一、前期准备 提示&#xff1a;下面所有学习内容都是基于以下条件完成的 条件1.已经可以正常访问交换机的命令行接口 Console口本地访问教程参考 ① &#xff1a;使用第三方工具&#xff08;secureCRT软件&#xff09;通过console口本地访问访问交换机的详细操作过程 Telnet访…

静态路由配置注意事项及黑洞路由的使用

静态路由 1 . 定义 从管理员处学习到的数据转发路径&#xff0c;就称为静态路由。 2 . 路由表 Proto &#xff1a;协议&#xff08; Protocol &#xff09; Direct — 直连链路Static — 静态路由RIP 、OSPF 等 — 动态路由 Pre : 优先级&#xff08; Preference &#x…

防爆手机终端安全管理平台

防爆手机终端安全管理平台能够满足国家能源、化工企业对安全生产信息化运行需求&#xff0c;能够快速搭建起高效、快捷的移动终端管理平台&#xff0c;提高企业安全生产管理水平&#xff0c;保证企业的安全运行和可持续发展。#防爆手机 #终端安全 #移动安全 能源、化工等生产单…

windows机器免密登录linux主机

1. 正常连接需要输入密码 ssh root1.1.1.1 2. 在Windows上生成SSH密钥对&#xff08;如果你还没有的话&#xff09;&#xff1a; ssh-keygen 3. scp将id_rsa.pub传输到对应的主机 4.对应机器上查看 5.从windows上免密登录

[数仓]四、离线数仓(Hive数仓系统-续)

第8章 数仓搭建-DWT层 8.1 访客主题 1)建表语句 DROP TABLE IF EXISTS dwt_visitor_topic; CREATE EXTERNAL TABLE dwt_visitor_topic (`mid_id` STRING COMMENT 设备id,`brand` STRING COMMENT 手机品牌,`model` STRING COMMENT 手机型号,`channel` ARRAY<STRING> C…

Vue笔记11-Composition API的优势

Options API存在的问题 使用传统Options API中&#xff0c;新增或者修改一个需求&#xff0c;就需要分别在data&#xff0c;methods&#xff0c;computed里修改&#xff0c;而这些选项分布在代码的各个地方&#xff0c;中间还穿插着其他Optional API&#xff0c;如果代码量上来…

AI自动生成PPT怎么用?看完这篇文章你就知道啦

小暑&#xff0c;作为夏季的第五个节气&#xff0c;标志着炎炎夏日的正式到来。在这个时节&#xff0c;阳光明媚&#xff0c;万物生长&#xff0c;人们的心情也随着气温的升高而变得热烈。 然而&#xff0c;对于许多职场人士来说&#xff0c;小暑的到来也意味着需要准备各种汇报…

如何使用matplotlib绘制可以指定大小的饼图

​ 如果想绘制指定大小的饼图&#xff0c;如直径5mm&#xff0c;可以参考本博文实现。 有此需求的起因是我有两个维度的数据想要用图形展示&#xff0c;第一个维度是每种场景下2021&#xff0c;2022和2023年的总容量&#xff0c;第二个维度是每种场景下2021&#xff0c;2022和…

德语疑难知识点

一&#xff0c;Relativpronomen im Genitiv &#xff08;1&#xff09;https://cn.godic.net/webting/desktopplay?id559661fd-265a-11ef-80ed-e747abc08a44&tokenQYNeyJ0b2tlbiI6IiIsInVzZXJpZCI6IiIsInVybHNpZ24iOiJaZytkb3F1OU1zMW9ubG4rNXBSMS9Ob00rUkk9IiwidCI6IkFCS…

Mac可以卸载掉系统自带的软件吗 Mac第三方软件无法卸载是为什么

在使用Mac电脑时&#xff0c;有时候我们会发现系统预装的一些应用并不常用或者不符合个人需求&#xff0c;想要将它们卸载掉。然而&#xff0c;对于系统自带的软件&#xff0c;卸载并不简单&#xff0c;需要谨慎对待以免影响系统稳定性和功能正常运行。下面我们来看看Mac可以卸…

HTML-CSS 入门介绍

1.web 网站的工作流程 2.web前端开发 简单示例 <html> <head> <title>HTML快速入门</title> </head> <body> <h1>Hello HTML</h1> <img src1.jpg></img> <img src1.jp…

园区智慧能源可视化:智能监控与优化能源管理

通过图扑可视化技术&#xff0c;搭建智慧光伏园区&#xff0c;实时监控园区光伏系统的运行状态&#xff0c;分析数据并优化能源管理&#xff0c;提高发电效率和维护效率&#xff0c;助力园区实现绿色可持续发展。

windows上部署python3.11

hello&#xff0c;大家好&#xff0c;我是一名测试开发工程师&#xff0c;至今已在自动化测试领域深耕9个年头&#xff0c;现已将本人实战多年的多终端自动化测试框架【wyTest】开源啦&#xff0c;在接下来的一个月里&#xff0c;我将免费指导大家使用wyTest&#xff0c;请大家…

[C++][ProtoBuf][初识ProtoBuf]详细讲解

目录 1.序列化概念2.ProtoBuf是什么&#xff1f;3.ProtoBuf使用特点4.补充1.GOOGLE_PROTOBUF_VERIFY_VERSION 宏2.ShutdownProtobufLibrary()3.--decode 5.序列化能力对比验证6.总结 1.序列化概念 序列化&#xff1a;把对象转换为字节序列的过程&#xff0c;称为对象的序列化反…

PHP灵活用工任务小灵通微信小程序系统源码

&#x1f4bc;灵活赚钱新风尚&#xff01;灵活用工任务小灵通微信小程序&#xff0c;兼职自由两不误&#x1f680; &#x1f50d; 一、海量任务&#xff0c;随时随地接单赚外快 还在为找不到合适的兼职而烦恼吗&#xff1f;&#x1f914; 灵活用工任务小灵通微信小程序&#…

使用花生壳内网穿透实现(HTTP、TCP)公网访问

文章目录 相关费用域名费用http/https 映射服务 管理平台客户端添加设备添加 SSH 映射映射诊断SSH 连接APP 端 相关费用 域名费用 http/https 映射服务 注&#xff1a; http/https 映射服务是 永久 开通一次性费用。 管理平台 https://console.hsk.oray.com/home 客户端 下载…

Lumerical Algorithm 查找最接近给定透射率值的波长值

Lumerical Algorothm 查找最接近给定透射率值的波长值 引言正文引言 在 Lumerical Script 算法,查找数组中对应值的所有索引值 一文中我们简单介绍了 Lumerical 中的索引值获取算法,这里,我们来介绍一下如何查找最接近给定透射率值的波长值。 正文 比如我们有如下透射率图…

物料主数据BAPI 无法写入扩展(增强)字段问题

在使用BAPI_MATERIAL_SAVEDATA 去创建物料时&#xff0c;因为有增强字段。这时候需要通过extensionin 字段 进行赋值。 https://community.sap.com/t5/application-development-discussions/bapi-material-savedata-extensionin-dec-type-dump/m-p/11760099 但是赋值后仍然没…