Codeforces | CF1028C 【Rectangles】

(这道题太简单啦...虽说我锤了一上午都没过...我能说这道题和\(CF1029C\)算是同一道题吗...)
按照时间顺序来说...\(CF1029\)在\(CF1028\)前面(而且\(CF1029\)还是\(Div3\)),前后没差多长时间就惊现高相似度题目(所以CF是有多迫切想让大家上分)
CF1029C传送门
两道题的唯一差别就是一个是一维,一个是二维(我是不是应该猜一下\(CF1036C\)会出一个三维的),都是范围覆盖,和\(CF1029C\)一样,只需要确定最严格的边界限制,题目要求输出任意一个在至少\(n-1\)个矩形内的点,也即可以删去一个矩形,输出剩下\(n-1\)个矩形的交集内的任意点(在此直接选用交集左下角的点)
根据题目条件,一定存在一些满足条件的点,所以删去的矩形应该是与其他\(n-1\)个矩形的交集没有公共部分的矩形,所以和\(CF1029C\)中的处理方式相似,在造成最严格限制的至多四个矩形中枚举删除即可,若删除后剩下的\(n-1\)个矩形交集不为空即可输出答案(如果\(n\)个矩形的交集不为空可以不删除)
下面放代码\(\downarrow\downarrow\downarrow\)

#include<cstdio>//CF1028C
#include<iostream>
#include<cstring>
#include<string>
#include<cmath>
#include<algorithm>
#include<cstdlib>
#include<queue>

using namespace std;

int n;

struct lborder{
    int x,id;
    bool operator<(const lborder&rhs)const{
        return x<rhs.x;
    }
};

struct rborder{
    int x,id;
    bool operator<(const rborder&rhs)const{
        return x>rhs.x;
    }
};

lborder lbx,lby;rborder rbx,rby;

priority_queue<lborder>ql[2];
priority_queue<rborder>qr[2];

int main(){
    scanf("%d",&n);
    for(int i=1;i<=n;i++){
        scanf("%d%d%d%d",&lbx.x,&lby.x,&rbx.x,&rby.x);
        lbx.id=rbx.id=lby.id=rby.id=i;
        ql[0].push(lbx);
        qr[0].push(rbx);
        ql[1].push(lby);
        qr[1].push(rby);
    }
    int id[2][4],x[2][4];
    id[0][0]=ql[0].top().id;id[0][1]=ql[1].top().id;
    id[0][2]=qr[0].top().id;id[0][3]=qr[1].top().id;
    x[0][0]=ql[0].top().x;x[0][1]=ql[1].top().x;
    x[0][2]=qr[0].top().x;x[0][3]=qr[1].top().x;
    ql[0].pop();qr[0].pop();ql[1].pop();qr[1].pop();
    id[1][0]=ql[0].top().id;id[1][1]=ql[1].top().id;
    id[1][2]=qr[0].top().id;id[1][3]=qr[1].top().id;
    x[1][0]=ql[0].top().x;x[1][1]=ql[1].top().x;
    x[1][2]=qr[0].top().x;x[1][3]=qr[1].top().x;
    int vis[4]={0,0,0,0},bor[4];
    if(x[0][0]<=x[0][2]&&x[0][1]<=x[0][3]){
            printf("%d %d\n",x[0][0],x[0][1]);
            return 0;
        }
    for(int i=0;i<4;i++){
        if(vis[i]){
            continue;
        }
        vis[i]=1;
        for(int j=0;j<4;j++){
            if(j==i){
                bor[j]=x[1][j];
            }
            else{
                bor[j]=x[0][j];
            }
        }
        for(int j=i+1;j<4;j++){
            if(id[0][j]==id[0][i]){
                bor[j]=x[1][j];
                vis[j]=1;
            }
        }
        if(bor[0]>bor[2]||bor[1]>bor[3]){
            continue;
        }
        else{
            printf("%d %d\n",bor[0],bor[1]);
            return 0;
        }
    }
    return 0;
}

原文地址:https://www.cnblogs.com/--BLUESKY007/p/9555128.html

时间: 2024-10-31 02:42:06

Codeforces | CF1028C 【Rectangles】的相关文章

Codeforces 479【E】div3

题目链接:http://codeforces.com/problemset/problem/977/E 题意:就是给你相连边,让你求图内有几个环. 题解:我图论很差,一般都不太会做图论的题.QAQ看官方题解过的.大概就是如果这是一个环的话,每一个点的度数都应该是2才对,根据这个进行dfs做标记. 就算是个简单图论,看到还是会一脸懵逼.QWQ.以后还是会多多写dfs和图论啦.不过个人还是更喜欢数论什么的. 1 #include<iostream> 2 #include<vector>

codeforces 1037E-Trips 【构造】

题目:戳这里 题意:n个点,每天早上会在这n个点中加一条边,每天晚上最大的子图满足子图中每个点都有k条或以上的边. 解题思路:看了官方题解,先把所有的点都连上,再从最后一天往前减边,用set维护最大的子图,注意每减去一条边时,更新该边两端点的状态. 1 #include <bits/stdc++.h> 2 using namespace std; 3 typedef long long ll; 4 const int maxn = 2e5 + 10; 5 int ans[maxn]; 6 st

Codeforces 1030D 【构造】

LINK 题目大意:给你n,m,k,让你在一个n*m的点阵里构造出一个面积为\(\frac{n*m}{k}\)的三角形 思路 首先要有一个结论是整点三角形的面积分母最多为2,然后就可以判断不存在的情况了 接下来就直接进行构造就可以了 #include<bits/stdc++.h> using namespace std; #define LL long long #define IL inline #define fu(a,b,c) for(LL a=b;a<=c;++a) #defin

Codeforces | CF1033D 【Divisors】

题目大意:给定\(n(1\leq n\leq500)\)个数\(a_1,a_2\cdots,a_n(1\leq a_i\leq2\cdot10^{18})\),每个数有\(3\sim5\)个因数,求\(\prod_{i=1}^{n}a_i\)的因数个数 这道题是一个交互题(虽说并不觉得有交互的必要...可能只是为了\(hack\)或者造数据方便吧),非常纯的数\((du)\)学\((liu)\),题目难度不在于结论,而在于代码实现 小学数学告诉我们以下结论:一个正整数\(x\)可以被分解成唯一形

【模拟】Codeforces 706A Beru-taxi

题目链接: http://codeforces.com/problemset/problem/706/A 题目大意: 家的坐标在sx,sy,有n辆车,每辆车坐标xi,yi,速度vi,问最快的一辆车什么时候到家. 题目思路: [模拟] 签到题. 1 // 2 //by coolxxx 3 // 4 #include<iostream> 5 #include<algorithm> 6 #include<string> 7 #include<iomanip> 8

【模拟】Codeforces 691B s-palindrome

题目链接: http://codeforces.com/problemset/problem/691/B 题目大意: 求一个字符串是不是镜像的(不是回文).是输出TAK否则RE. 题目思路: [模拟] 预处理镜像的字母,注意bd pq,从头尾开始模拟. 1 // 2 //by coolxxx 3 //#include<bits/stdc++.h> 4 #include<iostream> 5 #include<algorithm> 6 #include<strin

【模拟】Codeforces 691C Exponential notation

题目链接: http://codeforces.com/problemset/problem/691/C 题目大意: 输入一个数,把它表示成a·10b形式(aEb).输出aEb,1<=a<10,b如果为1要省略Eb 题目思路: [模拟] 如果字符串没有‘.'我就在最后加上一个'.'方便处理. 先把头尾多余的0去掉,然后把这个数按照'.'拆成两半,统计整数部分的位数zs. 接着统计'.'后面的0的个数xs,再把所有数字放到一个数组里,再把头多余的0去掉(0.0000xx). 之后按照zs和sx的

【模拟】Codeforces 691A Fashion in Berland

题目链接: http://codeforces.com/problemset/problem/691/A 题目大意: n个数0或1,要求恰好n-1个1,如果n为1则那个数一定要是1 题目思路: [模拟] 水题一道.看错题目两次.. 1 // 2 //by coolxxx 3 //#include<bits/stdc++.h> 4 #include<iostream> 5 #include<algorithm> 6 #include<string> 7 #in

【STL】Codeforces 696A Lorenzo Von Matterhorn

题目链接: http://codeforces.com/problemset/problem/696/A 题目大意: 一个满二叉树,深度无限,节点顺序编号,k的儿子是k+k和k+k+1,一开始树上的边权都为0 N(N<=1000)个操作,操作两种,1是从u到v的路径上的所有边权+w,2是求u到v的边权和.(1 ≤ v, u ≤ 1018, v ≠ u, 1 ≤ w ≤ 109) 题目思路: [STL] 用map写很快,第一次用很生疏.现学只看了一点点. 因为是满二叉树所以直接暴力求LCA和求解,