排座椅【详细代码题解】

[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 += 4if Xi == Pi:# 同一行,增加这一列的干扰计数col_interference[min(Yi, Qi)] += 1else:# 同一列,增加这一行的干扰计数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)))

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

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

相关文章

USB转RS485+RS232+TTL串口电路

USB转RS485RS232TTL电路 USB转RS485RS232TTL电路如下图所示&#xff0c;可实现USB转RS485RS232TTL串口&#xff0c;一个电路模块即可实现电路调试过程中用到常用接口。 电路模块上留有2.54MM单排针接口和接线端子两种接线方式&#xff0c;可接线和跳线。电路模块同时有5V和3.3V…

Postman脚本炼金术:高级数据处理的秘籍

&#x1f916; Postman脚本炼金术&#xff1a;高级数据处理的秘籍 Postman不仅是API测试的强大工具&#xff0c;它的脚本功能同样能够在数据处理方面大放异彩。无论是在请求之前设置环境&#xff0c;还是测试后验证结果&#xff0c;Postman的脚本都能提供强大的数据处理能力。…

开源浏览器引擎对比与适用场景:WebKit、Chrome、Gecko

WebKit与Chrome的Blink引擎对比 起源与关系&#xff1a; WebKit最初由苹果公司开发&#xff0c;用于Safari浏览器。后来&#xff0c;WebKit逐渐成为一个独立的开源项目&#xff0c;被多个浏览器厂商采用。Blink是Google基于WebKit项目分支出来的一个浏览器引擎&#xff0c;用于…

文献翻译与阅读《Integration Approaches for Heterogeneous Big Data: A Survey》

CYBERNETICS AND INFORMATION TECHNOLOGIES’24 论文原文下载地址&#xff1a;原文下载 目录 1 引言 2 大数据概述 3 大数据的异构性 4 讨论整合方法 4.1 大数据仓库&#xff08;BDW&#xff09; 4.2 大数据联盟&#xff08;BDF&#xff09; 5 DW 和 DF 方法的比较、分…

C++入门基础题:数组元素逆序(C++版互换方式)

1.题目&#xff1a; 数组元素逆置案例描述: 请声明一个5个元素的数组&#xff0c;并且将元素逆置. (如原数组元素为:1,3,2,5,4;逆置后输出结果为:4,5,2,3,1) 2.图解思路&#xff1a; 3.代码演示&#xff1a; #include<iostream>using namespace std;int main(){int a…

常见颜色汇总

目录 常见的8种颜色&#xff1a; 常见的32种颜色&#xff1a; 常见的8种颜色&#xff1a; colors_8 [(0, 0, 0), # Black(255, 255, 255), # White(255, 0, 0), # Red(0, 255, 0), # Lime(0, 0, 255), # Blue(255, 255, 0), # Yellow(0, 255, 255), …

[k8s源码]1.client-go集群外部署

client-go是由k8s发布且维护的专门用于开发者和kubernetes交互的客户端库。它支持对k8s资源的CRUD操作&#xff08;create、read、update、delete&#xff09;&#xff0c;事件监听和处理&#xff0c;访问kubernetes集群的上下文和配置。 client go是独立于kubernetes集群之外…

Rust vs Go: 特点与应用场景分析

目录 介绍Rust的特点Go的特点Rust的应用场景Go的应用场景总结 介绍 Rust和Go&#xff08;Golang&#xff09;是现代编程语言中两个非常流行的选择。凭借各自的独特优势和广泛的应用场景&#xff0c;吸引了大量开发者的关注。本文将详细介绍Rust和Go的特点&#xff0c;并探讨它…

[Linux][Shell][Shell逻辑控制]详细讲解

目录 1.if 判断1.if-then2.if-then-else3.elif4.case5.实际上手 2.条件测试0.事前说明1.test 命令2.[]3.双括号1.(())2.[[]] 4.实际上手 3.循环1.for2.while3.until命令4.控制循环1.break2.continue 5.处理循环的输出 1.if 判断 1.if-then 语法&#xff1a;if command thenco…

代码随想录算法训练营DAY60|并查集理论基础、寻找存在的路径

并查集理论基础 并查集主要有两个功能&#xff1a; 将两个元素添加到一个集合中。判断两个元素在不在同一个集合 复杂度分析 空间复杂度&#xff1a; O(n) &#xff0c;申请一个father数组。路径压缩后的并查集时间复杂度在O(logn)与O(1)之间&#xff0c;且随着查询或者合并操…

大数据------JavaWeb------VueElement(完整知识点汇总)

Vue 定义 Vue是一套前端框架&#xff0c;可以免除原生JavaScript中的DOM操作&#xff0c;简化书写 之前所学的MyBatis框架是用来简化JDBC代码编写的&#xff1b;而Vue是前端框架&#xff0c;用来简化JavaScript代码编写的 在Axios与JSON综合案例的添加中有大量的DOM操作&#…

Ubuntu 22.04.4 LTS (linux) 安装 Auditd 安全审计

1 安装auditd sudo apt update sudo apt-get install auditd 2 修改配置 #sudo vim /etc/audit/auditd.conf #日志文件位置 log_file /var/log/audit/audit.log #日志文件大小(Mb) max_log_file 8 #日志文件数量 num_logs 53 启动服务 sudo systemctl restart aud…

【密码学】数字签名

一、数字签名的基本概念 数字签名是一种用于验证电子文档完整性和身份认证的密码学技术。它通过使用公钥加密体系中的私钥对文档的一部分&#xff08;通常是文档的摘要&#xff09;进行加密&#xff0c;从而创建一个“签名”。这个签名可以附在文档上&#xff0c;或作为一个单独…

vue3实现vuedraggable实现拖拽到垃圾桶图标位置进行删除

当使用Vue 3和vuedraggable库时&#xff0c;你可以按照以下方式实现拖拽到垃圾桶图标位置进行删除的功能&#xff1a; 首先&#xff0c;确保你已经安装了vuedraggable库。如果没有安装&#xff0c;可以通过以下命令进行安装&#xff1a; vuedraggable 和vue-draggable-plus使…

力扣636.函数的独占时间

力扣636.函数的独占时间 用一个对组栈存每个start数据&#xff0c;first为编号&#xff0c;second为开始时间 start时&#xff1a;若栈为空 直接入栈 若不为空 处理前一段已独占的时间 end时&#xff1a;将自己的独占时间处理了 若栈非空 将栈顶元素的开始时间更新为当前时间1因…

如何将HEVC格式的视频转换为无损、未压缩的MP4格式视频?

在和大家分享视频格式转换之前&#xff0c;先跟大家分享一下HEVC格式的视频到底是什么文件&#xff1f;压缩原理是什么&#xff1f;了解了它的本质之后&#xff0c;我们就可以知道如何保证视频高清无损了。 如何将HEVC格式的视频转换为无损、未压缩的MP4格式视频&#xff1f; …

【Flask从入门到精通:第二课:flask加载项目配置的二种方式、路由的基本定义和终端运行】

flask加载项目配置的二种方式 # 1. 导入flask核心类 from flask import Flask# 2. 初始化web应用程序的实例对象 app Flask(__name__)"""第一种&#xff1a;flask项目加载站点配置的方式""" # app.config["配置项"] 配置项值 # app…

逐步实践复现 SELF-RAG

SELF-RAG 简介 SELF-RAG&#xff08;Self-Reflective Retrieval-Augmented Generation&#xff09;是一种检索增强生成&#xff08;RAG&#xff09;的框架&#xff0c;它通过自我反思学习检索、生成和批判&#xff0c;以提高大型语言模型&#xff08;LLM&#xff09;的质量和真…

通用业务指标管理系统设计

设计一个通用业务指标管理系统&#xff0c;旨在帮助企业全面监控和管理关键业绩指标(KPIs)&#xff0c;以驱动决策制定和业务优化。以下是一个综合性的设计方案&#xff0c;涵盖核心功能模块、技术架构、以及用户体验设计要点&#xff1a; 1. 核心功能模块 目标设定与分解 战…

「C++系列」一篇文章说透【存储类】

文章目录 一、C 存储类1. 类的定义2. 对象的创建3. 对象在内存中的布局4. 对象的存储位置 二、auto 存储类1. auto的基本用法2. auto与存储类的关系1) 自动存储类&#xff08;最常见的&#xff09;2) 静态存储类3) 动态存储类&#xff08;通过new&#xff09; 三、register 存储…