排座椅

排座椅

https://ac.nowcoder.com/acm/problem/16618

题目描述

上课的时候总有一些同学和前后左右的人交头接耳,这是令小学班主任十分头疼的一件事情。不过,班主任小雪发现了一些有趣的现象,当同学们的座次确定下来之后,只有有限的D对同学上课时会交头接耳。同学们在教室中坐成了M行N列,坐在第i行第j列的同学的位置是(i,j),为了方便同学们进出,在教室中设置了K条横向的通道,L条纵向的通道。于是,聪明的小雪想到了一个办法,或许可以减少上课时学生交头接耳的问题:她打算重新摆放桌椅,改变同学们桌椅间通道的位置,因为如果一条通道隔开了两个会交头接耳的同学,那么他们就不会交头接耳了。
请你帮忙给小雪编写一个程序,给出最好的通道划分方案。在该方案下,上课时交头接耳的学生对数最少。

输入描述:

第一行,有5各用空格隔开的整数,分别是M,N,K,L,D(2 ≤ N,M ≤ 1000,0 ≤ K < M,0 ≤ L < N,D ≤ 2000)。
接下来D行,每行有4个用空格隔开的整数,第i行的4个整数Xi,Yi,Pi,Qi,表示坐在位置(Xi,Yi)与(Pi,Qi)的两个同学会交头接耳(输入保证他们前后相邻或者左右相邻)。
输入数据保证最优方案的唯一性。

输出描述:

第一行包含K个整数,a1a2……aK,表示第a1行和a1+1行之间、第a2行和第a2+1行之间、…、第aK行和第aK+1行之间要开辟通道,其中ai < ai+1,每两个整数之间用空格隔开(行尾没有空格)。
第二行包含L个整数,b1b2……bk,表示第b1列和b1+1列之间、第b2列和第b2+1列之间、…、第bL列和第bL+1列之间要开辟通道,其中bi< bi+1,每两个整数之间用空格隔开(行尾没有空格)。

题解

简单贪心,我们要求总方案最优,那我们就选可以隔开最多交头接耳同学的行和列输出即可。

代码

#include<iostream>
#include<algorithm>
#include<map>
#include<vector>
#include<set>
#include<string>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<queue>
#include<stack>
using namespace std;
#define ll long long
#define ull unsigned long long
#define pb push_back
#define pii pair<int,int>
#define all(A) A.begin(), A.end()
#define fi first
#define se second
#define MP make_pair
#define rep(i,n) for(register int i=0;i<(n);++i)
#define repi(i,a,b) for(register int i=int(a);i<=(b);++i)
#define repr(i,b,a) for(register int i=int(b);i>=(a);--i)
template<typename T>
inline T read(){
    T s=0,f=1; char ch = getchar();
    while(!isdigit(ch)) {if(ch == '-') f=-1;ch = getchar();}
    while(isdigit(ch)) {s=(s<<3)+(s<<1)+ch-48;ch = getchar();}
    return s*f;
}
#define gn() read<int>()
#define gl() read<ll>()
template<typename T>
inline void print(T x) {
    if(x<0) putchar('-'), x=-x;
    if(x>9) print(x/10);
    putchar(x%10+'0');
}
////////////////////////////////////////////////////////////////////////
const int N=2e5+100;
int X[N],Y[N];
int id[N];
vector<int> ans;
////////////////////////////////////////////////////////////////////////
int main(){
    int n=gn(),m=gn(),k=gn(),l=gn(),d=gn();
    repi(i,1,d){
        int x=gn(),y=gn(),p=gn(),q=gn();
        if(x==p){
            ++Y[min(y,q)];
        } else {
            ++X[min(x,p)];
        }
    }
    repi(i,1,n)id[i]=i;
    sort(id+1,id+1+n,[](int x,int y){
        return X[x]>X[y];
    });
    for(int i=1;i<=k;++i){
        ans.pb(id[i]);
    }
    sort(all(ans));
     for(int i=0,len=ans.size();i<len;++i){
        printf("%d",ans[i]);
        if(i!=len-1)printf(" ");
    }
    putchar(10);
    ans.clear();
    repi(i,1,m)id[i]=i;
    sort(id+1,id+1+m,[](int x,int y){
        return Y[x]>Y[y];
    });
    for(int i=1;i<=l;++i){
        ans.pb(id[i]);
    }
    sort(all(ans));
    for(int i=0,len=ans.size();i<len;++i){
        printf("%d",ans[i]);
        if(i!=len-1)printf(" ");
    }
    putchar(10);
}
/**
* In every life we have some trouble
* When you worry you make it double
* Don't worry,be happy.
**/
每日一题 文章被收录于专栏

每日一题题解,在做题过程中不断提升

全部评论

相关推荐

目前这家已经离职了,想着要不要再找一份可以转正的实习,想着all&nbsp;in春招,春招之后再找实习,但是又没把握春招能拿到offer。现在已经有一段实习了,7月到12月,当时all&nbsp;in转正,但是没得,也错过了秋招。现在问题就是说在学校,临港,不租房的话通勤来回得5&nbsp;6个小时,租房又得倒贴实习,实习的话又没有经历去准备春招了。其实也是有可能毕业后往广东那边发展的,离家近一点,但是也就深圳java岗好一些。佬们路过能给晚辈一点建议吗。
黑皮白袜臭脚体育生:有实习经历除非到春招前能找到比实习经历title好的多的公司,不建议再找一段实习了,拿这段时间出来沉淀allin春招,春招后期还有补录,虽然机会不多但同样的竞争对手也不会多了,其实和春招高峰期相比拿offer难度差距不大,实在没拿到正式offer到五月份还有招25届的转正实习,再不行25届还能进一些接收应届生的社招岗,都有机会的另外宣传下自己的开源仿b站微服务项目,GitHub已经390star,牛客上有完整文档教程,如果觉得有帮助的话可以点个小星星,蟹蟹
点赞 评论 收藏
分享
11-09 01:22
已编辑
东南大学 Java
高级特工穿山甲:羡慕,我秋招有家企业在茶馆组织线下面试,约我过去“喝茶详谈”😢结果我去了发现原来是人家喝茶我看着
点赞 评论 收藏
分享
在拧螺丝的代码渣渣很喜欢后仰跳投:卖课的,拉黑就行了
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务