HJ171 排座椅

  • 题目
  • 题解(42)
  • 讨论(19)
  • 排行

简单 通过率:43.50% 时间限制:1秒 空间限制:50M

知识点贪心

校招时部分企业笔试将禁止编程题跳出页面,为提前适应,练习时请使用在线自测,而非本地IDE。

描述

教室内共有 nn 行 mm 列座位,坐在第 ii 行第 jj 列同学的位置记为 (i,j)(i,j)。

为了方便进出,班主任计划设置 kk 条横向通道 (贯穿整列的水平通道)与 ll 条纵向通道 (贯穿整行的竖直通道)。通道位于相邻两行(或两列)之间。

班主任记录了 dd 对经常交头接耳的同学,他们的位置 (xi,yi)(xi​,yi​) 与 (pi,qi)(pi​,qi​) 保证相邻 (上下或左右)。她希望通过合理放置通道,使尽可能多的"交头接耳"对被通道隔开。

现请你输出唯一的最优方案,在该方案下,仍未被通道隔开的"交头接耳"对的数量最少。

输入描述:

第一行输入五个整数 n,m,k,l,d(2≦n,m≦103; 0<k<n; 0<l<m; 0<d≦2×min⁡{n×m,2×103})n,m,k,l,d(2≦n,m≦103; 0<k<n; 0<l<m; 0<d≦2×min{n×m,2×103})。

接下来 dd 行,每行输入四个整数 xi,yi,pi,qixi​,yi​,pi​,qi​,表示坐标 (xi,yi)(xi​,yi​) 与 (pi,qi)(pi​,qi​) 的两位同学会交头接耳,且两坐标上下相邻或左右相邻。

保证最优方案存在且唯一。

输出描述:

第一行输出 kk 个严格递增的整数 a1,a2,...,ak(1≦a1<⋯<ak≦n−1)a1​,a2​,...,ak​(1≦a1​<⋯<ak​≦n−1),在行 aiai​ 与 ai+1ai​+1 之间设置横向通道。

第二行输出 ll 个严格递增的整数 b1,b2,...,bl(1≦b1<⋯<bl≦m−1)b1​,b2​,...,bl​(1≦b1​<⋯<bl​≦m−1),在列 bibi​ 与 bi+1bi​+1 之间设置纵向通道。

示例1

输入:

复制代码
4 5 1 2 3
4 2 4 3
2 3 3 3
2 5 2 4

复制输出:

复制代码
2
2 4

复制说明:

复制代码

该样例如下图所示,蓝底斜线方格为第一对交头接耳的同学,绿底带叉方格为第二对交头接耳的同学,粉底带星方格为第三对交头接耳的同学。粗线代表通道。该划分方案为唯一最优方案。

示例2

输入:

复制代码
2 2 1 1 4
1 1 1 2
1 1 2 1
2 1 2 2
1 2 2 2

复制输出:

复制代码
1
1
cpp 复制代码
#include <functional>
#include <iostream>
#include <unordered_map>
#include<vector>
#include<algorithm>
using namespace std;




int main() {
    int n,m,k,l,d;cin>>n>>m>>k>>l>>d;
    unordered_map<int,int>row,col;
    
    for(int i=0;i<d;i++){
        int x1,y1,x2,y2;cin>>x1>>y1>>x2>>y2;
        //贪心同行
        if(x1==x2){
            ++row[min(y1,y2)];
        }//贪心同列
        else if(y1==y2){
            ++col[min(x1,x2)];
        }
    }
    vector<pair<int,int> >vec_row,vec_col;
    for(auto&p:row){
        vec_row.emplace_back(p.second,p.first);
    }
    for(auto&p:col){
        vec_col.emplace_back(p.second,p.first);
    }
    //从大到小排序
    sort(vec_row.begin(),vec_row.end(),greater<pair<int,int> >());
    sort(vec_col.begin(),vec_col.end(),greater<pair<int,int> >());
    //输出按从小到大
    vector<int>rows,cols;
    for(int i=0;i<l&&i<vec_row.size();++i){
        rows.push_back(vec_row[i].second);
    }
    for(int i=0;i<k;++i){
        cols.push_back(vec_col[i].second);
    }
    sort(rows.begin(),rows.end());
    sort(cols.begin(),cols.end());
    for(auto&it:cols){
        cout<<it<<" ";
    }
    cout<<endl;
    for(auto&it:rows){
        cout<<it<<" ";
    }

}
// 64 位输出请用 printf("%lld")
相关推荐
吃好睡好便好21 小时前
用while循环语句求和
开发语言·学习·算法·matlab·信息可视化
王璐WL21 小时前
【C语言入门级教学】函数的概念2
c语言·数据结构·算法
不知名的忻1 天前
B 树与 B+ 树:面试完全指南
b树·算法·面试·b+树
运筹vivo@1 天前
2657. 找到两个数组的前缀公共数组 | 难度:中等
算法·leetcode·职场和发展·哈希表
索木木1 天前
NCCL SHARP 和 TREE算法
java·服务器·算法
Lumbrologist1 天前
【C++】零基础入门 · 第 1 节:第一个程序 Hello World 与编译运行
开发语言·c++
_李小白1 天前
【C++学习笔记】新特性之inline变量
c++·笔记·学习
心中有国也有家1 天前
hccl 架构拆解:昇腾集合通信库到底在做什么?
人工智能·经验分享·笔记·分布式·算法·架构
桀人1 天前
C++——模板初阶(收录在专栏C++入门到精通)
开发语言·c++
小O的算法实验室1 天前
2026年MCS,Q-learning增强MOPSO与改进DWA融合算法+复杂三维地形下特定移动机器人动态路径规划
算法