牛客小白月赛16 小石的妹子 二分 or 线段树
这个题目我AC之后看了一下别人的题解,基本上都是线段树,不过二分也可以。
这个题目很自然就肯定要对其中一个进行排序,排完序之后再处理另外一边,另一边记得离散化。
怎么处理呢,你仔细想想,找找规律就可以发现,其实我们就是在找递增子序列。
第一次找到的就是重要程度为1 的妹子,然后删除这些元素,继续第二次找,第二次找到的就是重要程度为二的妹子。
所以到每一个点,我们就只要根据它的大小来判断它应该放的位置(尽量靠前,并且小于这个数),然后更新这个位置,再返回这个位置,它所在的位置就是它的重要程度。
emmm 其实就是用一个数组,数组的每一个位置 i 存的就是到目前位置重要程度为 i 的最大值。
具体看代码吧。
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <queue>
#include <vector>
#include <algorithm>
#include <string>
#include <iostream>
#include <map>
#define inf 0x3f3f3f3f
#define inf64 0x3f3f3f3f3f3f3f3f
using namespace std;
const int maxn = 2e5 + ;
typedef long long ll;
int num[maxn];
map<ll, ll>mp;
struct node
{
int l, r;
int sum;
}tree[*maxn];
struct edge
{
ll a, b, id, num, ans;
}ex[maxn]; bool cmp(edge a,edge b)
{
return a.a > b.a;
} bool cmp1(edge a,edge b)
{
return a.b < b.b;
} bool cmp2(edge a,edge b)
{
return a.id < b.id;
} int tot = ;
int ok(ll x)
{
if (x > num[]) return ;
if (x < num[tot])
{
tot++;
return tot;
}
int l = , r = tot, ans = ;
int mid = (l + r) >> ;
while (l <= r) {
int mid = (l + r) / ;
if (num[mid]<x) ans = mid, r = mid - ;
else l = mid + ;
}
return ans;
} int main()
{
int n;
scanf("%d", &n);
for (int i = ; i <= n; i++) {
scanf("%lld%lld", &ex[i].a, &ex[i].b), ex[i].id = i;
}
sort(ex + , ex + + n, cmp1);
for (int i = ; i <= n; i++) mp[ex[i].b] = i;
sort(ex + , ex + + n, cmp);
num[] = mp[ex[].b];
ex[].ans = ;
tot = ;
for(int i=;i<=n;i++)
{
int f = ok(mp[ex[i].b]);
// printf("%lld ex[%d]=%lld f=%d\n",mp[ex[i].b], i, ex[i].b, f);
num[f] = mp[ex[i].b];
ex[i].ans = f;
}
sort(ex + , ex + + n, cmp2);
for (int i = ; i <= n; i++) printf("%lld\n", ex[i].ans);
return ;
}
二分
网上的线段树的方法我感觉和逆序对有点像,就是首先还是把 b 离散化,然后对 a 进行排序,
然后从 1 ~ n 遍历,如果对于每一个 b 首先判断 b ~ n 有没有值,其实就是有没有比 b 大的再前面放过了,有的话就去最大值,重要程度就是 最大值+1 (这个是因为存进去的就是最大值)
没有那么重要程度就是 1 ,然后再更新这个点 b 把 b 的重要程度放到线段树的 b 这个位置以便后面的查询。
这个很好写的。
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <queue>
#include <vector>
#include <algorithm>
#include <string>
#include <iostream>
#include <map>
#define inf 0x3f3f3f3f
#define inf64 0x3f3f3f3f3f3f3f3f
using namespace std;
const int maxn = 2e5 + ;
typedef long long ll;
map<ll, ll>mp;
struct node
{
int l, r;
int num;
}tree[*maxn];
struct edge
{
ll a, b, id, num, ans;
}ex[maxn]; bool cmp(edge a,edge b)
{
return a.a > b.a;
} bool cmp1(edge a,edge b)
{
return a.b < b.b;
} bool cmp2(edge a,edge b)
{
return a.id < b.id;
} void build(int id, int l, int r) {
tree[id].l = l;
tree[id].r = r;
if (l == r) {
tree[id].num = ;
return;
}
int mid = (l + r) >> ;
build(id << , l, mid);
build(id << | , mid + , r);
} int query(int id, int x, int y) {
int l = tree[id].l;
int r = tree[id].r;
if (x <= l && y >= r) {
// printf("id=%d sum=%d \n", id,tree[id].sum);
return tree[id].num;
}
int ans = ;
int mid = (l + r) >> ;
if (x <= mid) ans = max(ans, query(id << , x, y));
if (y > mid) ans = max(ans, query(id << | , x, y));
// printf("id=%d ans=%d l=%d r=%d x=%d y=%d \n", id, ans, l, r,x,y);
return ans;
} void push_up(int id) {
tree[id].num = max(tree[id << ].num , tree[id << | ].num);
} void update(int id, int x,int val) {
int l = tree[id].l;
int r = tree[id].r;
if (l == r) {
tree[id].num = val;
return;
}
int mid = (l + r) >> ;
if (x <= mid) update(id << , x,val);
else update(id << | , x,val);
push_up(id);
} int main()
{
int n;
scanf("%d", &n);
for (int i = ; i <= n; i++) {
scanf("%lld%lld", &ex[i].a, &ex[i].b), ex[i].id = i;
}
sort(ex + , ex + + n, cmp1);
for (int i = ; i <= n; i++) mp[ex[i].b] = i;
sort(ex + , ex + + n, cmp);
build(, , n);
for(int i=;i<=n;i++)
{
int f = query(, mp[ex[i].b], n) + ;
ex[i].ans = f;
update(, mp[ex[i].b],f);
}
sort(ex + , ex + + n, cmp2);
for (int i = ; i <= n; i++) printf("%lld\n", ex[i].ans);
return ;
}
逆序对 线段树
牛客小白月赛16 小石的妹子 二分 or 线段树的更多相关文章
- 牛客小白月赛16 F 小石的妹子 (线段树)
链接:https://ac.nowcoder.com/acm/contest/949/F来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言52428 ...
- 牛客小白月赛16 A 小石的签到题 ( 博弈)
链接:https://ac.nowcoder.com/acm/contest/949/A来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言52428 ...
- 牛客小白月赛16 E 小雨的矩阵 ( 暴搜)
链接:https://ac.nowcoder.com/acm/contest/949/E来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言52428 ...
- 牛客小白月赛16 H 小阳的贝壳 (差分+线段树)
链接:https://ac.nowcoder.com/acm/contest/949/H来源:牛客网 题目描述 小阳手中一共有 n 个贝壳,每个贝壳都有颜色,且初始第 i 个贝壳的颜色为 colico ...
- 牛客小白月赛16 D 小阳买水果 (思维题)
链接:https://ac.nowcoder.com/acm/contest/949/D来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言52428 ...
- 牛客小白月赛16 H小阳的贝壳 (线段树+差分数组)
链接:https://ac.nowcoder.com/acm/contest/949/H来源:牛客网 题目描述 小阳手中一共有 n 个贝壳,每个贝壳都有颜色,且初始第 i 个贝壳的颜色为 colico ...
- 树的最长链-POJ 1985 树的直径(最长链)+牛客小白月赛6-桃花
求树直径的方法在此转载一下大佬们的分析: 可以随便选择一个点开始进行bfs或者dfs,从而找到离该点最远的那个点(可以证明,离树上任意一点最远的点一定是树的某条直径的两端点之一:树的直径:树上的最长简 ...
- 牛客网 牛客小白月赛5 I.区间 (interval)-线段树 or 差分数组?
牛客小白月赛5 I.区间 (interval) 休闲的时候写的,但是写的心情有点挫,都是完全版线段树,我的一个队友直接就水过去了,为啥我的就超内存呢??? 试了一晚上,找出来了,多初始化了add标记数 ...
- 牛客小白月赛8 - E - 诡异数字 数位DP
牛客小白月赛8 - E - 诡异数字 题意: 求区间中,满足限制条件的数字的个数. 限制条件就是某些数字不能连续出现几次. 思路: 比较裸的数位DP, DP数组开一个dp[len][x][cnt] 表 ...
随机推荐
- CVE-2019-17671:wrodpress 未授权访问漏洞-复现
0x00 WordPress简介 WordPress是一款个人博客系统,并逐步演化成一款内容管理系统软件,它是使用PHP语言和MySQL数据库开发的,用户可以在支持 PHP 和 MySQL数据库的服务 ...
- Redis之ziplist源码分析
一.ziplist简介 从上一篇分析我们知道quicklist的底层存储使用了ziplist(压缩列表),由于压缩列表本身也有不少内容,所以重新开了一篇,在正式源码之前,还是先看下ziplist的特点 ...
- Jenkins 批量创建任务的三种方法
最近,要搭建多套测试环境,需要把 Jenkins 中 dev 视图下的所有任务批量复制到 sit 等视图下. 说明 Jenkins 任务名称规则为:[测试环境标识]-[工程名称],如:dev-daod ...
- Jingwen‘s update
Bugs: The checkin button of the question answering page must be pressed twice to check in the result ...
- mapstruct使用详解
我们都知道,随着一个工程的越来越成熟,模块划分会越来越细,其中实体类一般存于 domain 之中,但 domain 工程最好不要被其他工程依赖,所以其他工程想获取实体类数据时就需要在各自工程写 mod ...
- mysql 创建表 索引 主键 引擎 自增 注释 编码等
CREATE TABLE text(id INT(20) COMMENT '主键',NAME VARCHAR(20) COMMENT '姓名',PASSWORD VARCHAR(20) COMMENT ...
- php7.2.1+redis3.2.1 安装redis扩展(windows系统)
前提:已成功安装PHP环境和Redis服务 下面进入正题: 第一步,下载redis驱动扩展文件,注意:需要根据上面信息下载对应版本 https://windows.php.net/downloads/ ...
- [PHP][linux] 命令行脚本接收传入参数的
第一种 :用{ $argv }接受参数 第二种 : getopt() 第三种:
- [PHP] 文件创建、写入、读取
创建$p = fopen('text.txt','a+b'); 写入第一种方式//var_export方式存储数组到文件中 //这中方式存浮点型数据,存储后会多很多数字!只适合简单的存储吧!我感觉! ...
- iview使用之怎样通过render函数在table组件表头添加图标及判断多个状态
在实际项目开发中,我们经常会用到各种各样的表格,比如在表格中填加下拉菜单,按钮,图标及可以根据状态显示对应文字等等,因为这段时间一直在做后台管理系统,所以表格用的就比较多,当然UI组件库我用的是ivi ...