阻挡广告牌

using namespace std;
#define x first
#define y second
typedef pair<int, int> PII;
const int N = 1e6 + 10;
PII x ={1000, -1000} , y = {-1000, 1000}, xx = {1000, -1000}, yy = {-1000,1000};
int main()
{
    PII a[2], b[2],c[2];
    cin >> a[0].x >>a[0].y >>a[1].x >>a[1].y; 
    cin >> b[0].x >>b[0].y >>b[1].x >>b[1].y; 
    cin >> c[0].x >>c[0].y >>c[1].x >>c[1].y; 
    bool t = false, tt = false;
    for(int i = c[0].x; i <= c[1].x; i ++)
    {
        for(int j = c[0].y; j <= c[1].y; j ++)
        {
            if(i >= a[0].x && i <= a[1].x && j >= a[0].y && j <= a[1].y)
            {
                t = true;
                if(i <= x.x && j >=x.y)
                {
                    x = {i, j};
                }
                if(i >= y.x&&j <= y .y)
                {
                    y = {i,j};
                }
            }
            if(i >= b[0].x && i <= b[1].x && j >= b[0].y && j <= b[1].y)
            {
                tt = true;
                if(i <= xx.x&&j >=xx.y)
                {
                    xx = {i, j};
                }
                if(i >= yy.x&&j <= yy .y)
                {
                    yy = {i,j};
                }
            }
        }
    }
    int ans = (abs(a[0].x - a[1].x)) * (abs(a[1].y - a[0].y)) + (abs(b[0].x - b[1].x)) * (abs(b[1].y - b[0].y));
    if(t) ans -=  (abs(y.x - x.x)) * (abs(y.y - x.y));
    if(tt) ans -= (abs(yy.y - xx.y)) * (abs(yy.x - xx.x));
     cout << ans << endl;
}
全部评论

相关推荐

缓解焦虑的最好方法是回家。鼠鼠昨天上午考完了本科阶段的最后一场考试,大概率考得稀烂,但是没多想,考完立马收拾行李,坐上了提前约好的顺风车飞奔回家。虽然家和学校很近,只有一百多公里的路程,但距离上次回家也已经有三四个月了。每次想回家,期间总有考试、毕业设计、面试、实习等等各种各样的原因,没办法回去,待在学校和公司的每一天也都充斥着无形的压力和焦虑。现在终于完成了答辩,考完了试,公司那边也请了假,是时候回去一趟了。没有提前通知爸妈,想给他们一个惊喜。下午提前到了家,他俩还在上班,只好让外公外婆来给我开门。因为我的回家,晚上外婆在厨房格外忙碌,做了满满一大桌子菜,填饱了我天天吃外卖的肚子。晚上也没空...
梦想是成为七海千秋:取决于家庭吧?其实回家更焦虑了,每天起床父母都问实习找好了没简历投递了没今天有没有面试,但是又没有什么结果,玩两下手机父母就会说你看你啥也没找到为什么天天就知道刷手机,怎么不去学习…我现在就希望我能永远在外面实习,报喜不报忧,等拿到一个好offer再回家
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务