codeforces AIM Tec round 5(div1+div2) C. Rectangles

这道题注意矩形的交集还是矩形,所以求交集搞出一个类似于前缀和后缀和的东西,从头到位暴力,只要满足出去当前矩形的其余n-1个的交集满足左下角小于等于右下角就可以啦

#include<bits/stdc++.h>
using namespace std;
struct rectangle{
    int x1,y1,x2,y2;
    rectangle operator + (const rectangle &rec)
    {
        rectangle newrec;
        newrec.x1=max(x1,rec.x1);
        newrec.y1=max(y1,rec.y1);
        newrec.x2=min(x2,rec.x2);
        newrec.y2=min(y2,rec.y2);
        return newrec;
    }
}pre[200000],suf[200000],rec[200000];
int main()
{
    int n;
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
    {
        int x1,y1,x2,y2;
        scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
        rec[i].x1=x1;
        rec[i].x2=x2;
        rec[i].y1=y1;
        rec[i].y2=y2;
    }
    pre[1]=rec[1];
    for(int i=2;i<=n;i++)
    {
        pre[i]=rec[i]+pre[i-1];
    }
    suf[n]=rec[n];
    for(int i=n-1;i>=1;i--)
    {
        suf[i]=rec[i]+suf[i+1];
    }
    for(int i=1;i<=n;i++)
    {
        rectangle now;
        if(i==1)
        {
           now=suf[2];
        }
        else if(i==n)
        {
            now=pre[n-1];
        }
        else
        {
            now=pre[i-1]+suf[i+1];
        }
        if(now.x1<=now.x2&&now.y1<=now.y2)
        {
            printf("%d %d\n",now.x1,now.y1);
            break;
        }
    }
}

原文地址:https://www.cnblogs.com/lishengkangshidatiancai/p/10257302.html

时间: 2024-10-18 04:52:32

codeforces AIM Tec round 5(div1+div2) C. Rectangles的相关文章

Codeforces Round #285 Div1 A and Div2 C

Problem 给一个图G,保证G是一个森林(坑!).图G含有N个点,给出每个点的两个属性:度数(degree).异或和(sum).度数表示该点与多少个点相连,异或和表示与其相连的点的编号的异或和(点编号从0开始,若度数为0则异或和为0).要求求出原图,输出边的个数和每条边两端的顶点. Limits Time Limit(ms): 1000 Memory Limit(MB): 256 N: [1, 2^16] degree: [0, N-1] Solution 由于G是森林,G的每一个连通图一定

Codeforces Round #FF(255) DIV2 C - DZY Loves Sequences

A - DZY Loves Hash 水题,开辟一个数组即可 #include <iostream> #include <vector> #include <algorithm> #include <string> using namespace std; int main(){ int p,n; cin >> p >> n; vector<bool> buckets(302,false); bool flag = fal

Codeforces Round #290 Div1 A

Problem 给N串字符串Si,通常定义字典序大小关系为 'a'<'b'<'c'<......<'y'<'z',现要求重新定义大小关系使得对于任意 i,j(i<j)满足Si <Sj,输出大小关系(一串'a'-'z'的排列),或者输出不存在(任意大小关系都不能满足要求). Limits Time Limit(ms): 2000 Memory Limit(MB): 256 N: 100 |Si|: 100 Solution 用图论方法解决,发现满足拓扑关系.枚举相邻

Codeforces Round #290 Div1 B

Problem 有一只青蛙在x轴上跳,起初在原点,现有N种跳跃技能可以购买,每技能有两属性:跳跃长度Li 以及 花费Ci.若购买了第 i 种技能,则可以从 y 位置跳跃到 y+Li 或者 y-Li 位置,但需花费Ci 元.求最小花费使得青蛙可以跳到每一个整数点上,若无法做到,输出-1. Limits Time Limit(ms): 2000 Memory Limit(MB): 256 N: 300 Li: [1, 10^9] Ci: [1, 10^5] Solution 若购买了n个属性使得青蛙

[Codeforces Round #444 div1] C.DZY Loves Colors 【线段树】

题目链接:CF Round #444 div1 C 题目分析 这道题目是要实现区间赋值的操作,同时还要根据区间中原先的值修改区间上的属性权值. 如果直接使用普通的线段树区间赋值的方法,当一个节点表示的区间完全被要求修改的区间包含时,就直接打上赋值的标记然后 return .但是这样这个节点中每个位置原先的值不同,需要进行的属性权值修改也就不同,是不能直接实现的.如果我们在节点表示的区间被修改的区间包含时,并不直接打标记 return ,而是当节点表示的区间被修改的区间完全包含而且这个节点中的每个

Codeforces Round #326(Div2)

CodeForces 588A 题意:Duff喜欢吃肉,想在接下来的n天,每天都有Ai斤肉吃,但每一天肉的单价Pi不定,肉 可以保存不过期,现已知n天每天肉的斤数Ai,以及单价Pi,为了使每天都             有想要的Ai斤肉吃,求最小花费.  思路:cost=Ai*min(pi)  1<=i<=n; 代码: 1 #include <iostream> 2 #include <cstdio> 3 #include <cstring> 4 using

Codeforces Round #328(Div2)

CodeForces 592A 题意:在8*8棋盘里,有黑白棋,F1选手(W棋往上-->最后至目标点:第1行)先走,F2选手(B棋往下-->最后至目标点:第8行)其次.棋子数不一定相等,F1,F2中其中一个           棋子最先到达目标点对应方胜利. 思路:W,B棋子分别只能上.下,所以需知道:离第一行最近的W棋距离S1(并且这个W上方没有B),离第八行最近的B棋距离S2(这个B下方没有W) 胜利者为 S1<=S2?F1:F2 注意:S1==S2时 F1胜. 代码: 1 #inc

Codeforces Round #391 div1 757F (Dominator Tree)

首先先膜杜教orz 这里简单说一下支配树的概念 支配树是对一个有向图来讲的 规定一个起点s,如果s到v的路径上必须经过某些点u,那么离s最近的点u就是v的支配点 在树上的关系就是,v的父亲是u. 一般图的支配树需要使用tarjan算法,但是如果有向图是没有环的,可以采用另一种做法 按照拓扑序建立支配树,每次加点的时候,枚举能到它的所有点,求它们在当前支配树的最近公共祖先,那个点就是该点的支配点 这个题先建立一个最短路图,易知,这个图是没有环的有向图,所以建立支配树的时候就可以采用以上做法 orz

Codeforces Round #295 Div1 B(Cubes)

Problem Limits TimeLimit(ms):3000 MemoryLimit(MB):256 M∈[1,105] Xi∈[?109,109] Yi∈[0,109] Look up Original Problem From here Solution 一个点可取,当且仅当,把它取了之后,上面的点不会失去平衡而掉下来. 开两个优先队列q1,q2.q1的顶元素最大,q2的顶元素最小,起初把所有可取的点都放入q1,q2,然后,轮流从q1,q2取点,如果访问过了就取下一个,取出点后,判断这