弱弱的战壕

描述

永恒和mx正在玩一个即时战略游戏,名字嘛~~~~~~恕本人记性不好,忘了-_-b。

mx在他的基地附近建立了n个战壕,每个战壕都是一个独立的作战单位,射程可以达到无限(“mx不赢定了?!?”永恒ftING...@_@)。

但是,战壕有一个弱点,就是只能攻击它的左下方,说白了就是横纵坐标都不大于它的点(mx:“我的战壕为什么这么菜”ToT)。这样,永恒就可以从别的地方进攻摧毁战壕,从而消灭mx的部队。

战壕都有一个保护范围,同它的攻击范围一样,它可以保护处在它左下方的战壕。所有处于它保护范围的战壕都叫做它的保护对象。这样,永恒就必须找到mx的战壕中保护对象最多的点,从而优先消灭它。

现在,由于永恒没有时间来计算,所以拜托你来完成这个任务:

给出这n个战壕的坐标xi、yi,要你求出保护对象个数为0,1,2……n-1的战壕的个数。

格式

输入格式

第一行,一个正整数n(1<=n<=15000)
接下来n行,每行两个数xi,yi,代表第i个点的坐标
(1<=xi,yi<=32000)
注意:可能包含多重战壕的情况(即有数个点在同一坐标)

输出格式

输出n行,分别代表保护对象为0,1,2……n-1的战壕的个数。

样例1

样例输入1

5
1 1
5 1
7 1
3 3
5 5

样例输出1

1
2
1
1
0

限制

各点2s(算是宽限吧^_^)

来源

URAL1028战役版

题目链接:https://vijos.org/p/1066

分析:先给出我线段树写法吧,XX了几个小时,一行代码,三个错误,我也是无语了!好不容易过了样例,啪啪啪,打脸了,才过了三组数据,查了半天只要改了右区间就会过qwq!

此题是要我们求每次有一个新的点加入时,比它小的y有几个,因为,先对X从小到大排序以后,每次加入一个y,之前比它小的y保证x和y都小于它,个数就是这个星星的等级这就可以这样,一个1-32000的线段,每次加入一个y,加入了一个[y,32000]的线段,然后每次看比y少的点有几个,就是它当前被压在几条线段下!

下面给出线段树写法:

 #include <bits/stdc++.h>
using namespace std;
const int N=;
int ans[N<<];
struct Node
{
int l,r,sum;
}tree[N<<];
struct data
{
int x,y;
}f[N<<];
inline bool cmp(data a,data b)
{
return (a.x==b.x)?(a.y<b.y):(a.x<b.x);
}
void buildtree(int l,int r,int pos)
{
tree[pos].sum=;
tree[pos].l=l;
tree[pos].r=r;
if(l==r)
return;
int mid=(l+r)/;
buildtree(l,mid,pos*);
buildtree(mid+,r,pos*+);
}
void update(int st,int ed,int pos)
{
if(tree[pos].l==st&&tree[pos].r==ed)
{
tree[pos].sum++;
return;
}
if(tree[pos].l==tree[pos].r)
return;
int mid=(tree[pos].l+tree[pos].r)/;
if(mid>=ed)
update(st,ed,pos*);
else if(st>mid)
update(st,ed,pos*+);
else
{
update(st,mid,pos*);
update(mid+,ed,pos*+);
}
}
int query(int c,int pos)
{
if(tree[pos].l==tree[pos].r)
return tree[pos].sum;
int mid=(tree[pos].l+tree[pos].r)/;
if(c<=mid)
return tree[pos].sum+query(c,pos*);
else return tree[pos].sum+query(c,pos*+);
}
int main()
{
int n;
cin>>n;
buildtree(,,);
for(int i=;i<n;i++)
scanf("%d%d",&f[i].x,&f[i].y);
sort(f,f+n,cmp);
for(int i=;i<n;i++)
{
ans[query(f[i].y,)]++;
update(f[i].y,,);
}
for(int i=;i<n;i++)
cout<<ans[i]<<endl;
return ;
}

此题数据太弱,所以用暴力同样可以解决问题!

 #include <bits/stdc++.h>
using namespace std;
const int N=;
struct Node
{
int x,y;
}p[N<<];
int n,ans[N<<];
int main()
{
cin>>n;
for(int i=;i<n;i++)
cin>>p[i].x>>p[i].y;
for(int i=;i<n;i++)
{
int tot=;
for(int j=;j<n;j++)
{
if(i==j)
continue;
else if(p[i].x>=p[j].x&&p[i].y>=p[j].y)
tot++;
}
ans[tot]++;
}
for(int i=;i<n;i++)
cout<<ans[i]<<endl;
return ;
}

其实呢,此题貌似用树状数组也行啊,只能说数据太水qwq!

树状数组,对X排下序之后以每个点的y进行操作。如果在某次算出sum(y)之后,肯定就是他的等级。因为在它之前的点都是x比它小或者和它相等,但是y没他大的。

 #include <bits/stdc++.h>
using namespace std;
const int N=;
struct Node
{
int x,y;
}p[N<<];
int n,c[N<<],ans[N<<];
int lowbit(int x)
{
return x&-x;
}
inline bool cmp(Node p,Node q)
{
return p.x==q.x?(p.y<q.y):(p.x<q.x);
}
int sum(int x)
{
int ret=;
while(x>)
{
ret+=c[x];
x-=lowbit(x);
}
return ret;
}
void add(int x)
{
while(x<=)
{
c[x]++;
x+=lowbit(x);
}
}
int main()
{
cin>>n;
for(int i=;i<=n;i++)
cin>>p[i].x>>p[i].y;
sort(p+,p++n,cmp);
for(int i=;i<=n;i++)
{
ans[sum(p[i].y)]++;
add(p[i].y);
}
for(int i=;i<n;i++)
cout<<ans[i]<<endl;
return ;
}

Vijos P1066 弱弱的战壕【多解,线段树,暴力,树状数组】的更多相关文章

  1. 树状数组训练题1:弱弱的战壕(vijos1066)

    题目链接:弱弱的战壕 这道题似乎是vijos上能找到的最简单的树状数组题了. 原来,我有一个错误的思想,我的设计是维护两个树状数组,一个是横坐标,一个是纵坐标,然后读入每个点的坐标,扔进对应的树状数组 ...

  2. VIJOS-P1066 弱弱的战壕

    JDOJ 1247: VIJOS-P1066 弱弱的战壕 题目传送门 Description 永恒和mx正在玩一个即时战略游戏,名字嘛~~~~~~恕本人记性不好,忘了--b. mx在他的基地附近建立了 ...

  3. 弱弱的玩下Javascript

    前言 好久没有更新博客了,也蛮少捣弄javascript,今儿看到一个题目,关于给你一个面板,你可以随意的在上面画矩形,可以移动和删除任意一个你创建的矩形,心血来潮搞着玩哈,实现起来挺简单的,但这代码 ...

  4. Vijos P1448 校门外的树【多解,线段树,树状数组,括号序列法+暴力优化】

    校门外的树 描述 校门外有很多树,有苹果树,香蕉树,有会扔石头的,有可以吃掉补充体力的…… 如今学校决定在某个时刻在某一段种上一种树,保证任一时刻不会出现两段相同种类的树,现有两个操作: K=1,K= ...

  5. hdu2838树状数组解逆序

    离散化和排序后的序号问题搞得我实在是头痛 不过树状数组解逆序和偏序一类问题真的好用 更新:hdu的数据弱的真实,我交上去错的代价也对了.. 下面的代码是错的 /* 每个点的贡献度=权值*在这个点之前的 ...

  6. BZOJ3110 K大数查询 【线段树 + 整体二分 或 树套树(非正解)】

    Description 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c 如果是2 a b c形式,表示询问从第a个位置到第b个位 ...

  7. 【vijos】P1066 弱弱的战壕

    [算法]线段树 [题解]将所有坐标按x(第一)和y(第二)从小到大排序,再按顺序插入线段树,即在线段树中将y坐标位置+1,这样就能保证每个坐标能包含的点一定先被处理了,每次询问查询1...a[i].y ...

  8. vijos 1066 弱弱的战壕 树状数组

    描述 永恒和mx正在玩一个即时战略游戏,名字嘛~~~~~~恕本人记性不好,忘了-_-b. mx在他的基地附近建立了n个战壕,每个战壕都是一个独立的作战单位,射程可以达到无限(“mx不赢定了?!?”永恒 ...

  9. [Vijos] 弱弱的战壕

    描述 永恒和mx正在玩一个即时战略游戏,名字嘛~~~~~~恕本人记性不好,忘了-_-b. mx在他的基地附近建立了n个战壕,每个战壕都是一个独立的作战单位,射程可以达到无限(“mx不赢定了?!?”永恒 ...

随机推荐

  1. LeetCode #1 TwoSum

    Description Given an array of integers, return indices of the two numbers such that they add up to a ...

  2. UITableView的性能优化1

    UITableView作为ios中使用最频繁的控件之一,其性能优化也是常常要面对的,尤其是当数据量偏大并且设备性能不足时.本文旨在总结tableview的几个性能优化tips,并且随着认识的深入,本文 ...

  3. KVO的内部实现以及使用

    转载自:http://www.cocoachina.com/applenews/devnews/2014/0107/7667.html   KVO是实现Cocoa Bindings的基础,它提供了一种 ...

  4. C#Linq技术中SelectMany(...)函数的内部实现的伪代码

    我们先来假设这种场景: 一个学校中有多个年级,一个年级有多个班级,一个班级里有多个学生.这里我们只需要班级.年级.和学生这三个概念: 让我们先来定义Class类和Student类: // 注意,Cla ...

  5. [数据结构]C语言链表实现

    我学数据结构的时候也是感觉很困难,当我学完后我发现了之所以困难时因为我没有系统的进行学习,而且很多教授都只是注重数据结构思想,而忽略了代码方面,为此我写了这些博文给那些试图自学数据结构的朋友,希望你们 ...

  6. mybatis的那些事

    转载请注明出处:http://www.cnblogs.com/yidaijiankuanzhongbuhui/p/7003993.html 用mybatis一年多了,一直是别人搭好框架,配置好各种配置 ...

  7. Java自己动手写连接池三

    Java自己动手写连接池三,核心代码; package com.kama.cn; import java.sql.Connection;import java.util.ArrayList;impor ...

  8. 用Python玩转微信(一)

    欢迎大家访问我的个人网站<刘江的博客和教程>:www.liujiangblog.com 主要分享Python 及Django教程以及相关的博客 交流QQ群:453131687 今天偶然看见 ...

  9. js写基础insertAfter()方法

    //DOM没有提供insertAfter()方法 function insertAfter(newElement, targetElement){ var parent = targetElement ...

  10. Python 实现接口类的两种方式+邮件提醒+动态导入模块+反射(参考Django中间件源码)

    实现接口类的两种方式 方式一 from abc import ABCMeta from abc import abstractmethod class BaseMessage(metaclass=AB ...