POJ2182 Lost Cows 题解
POJ2182 Lost Cows 题解
题目
有\(N\)(\(2 <= N <= 8,000\))头母牛,每头母牛有自己的独一无二编号(\(1..N\)).
现在\(N\)头母牛站成一列,已知每头母牛前面编号比它小的母牛数量,求每头母牛的编号.
输入格式
第1行 : 一个整数 \(N\)
第2..N行 : 从 第2头母牛到第N头母牛 的 前面编号比它小的母牛数量
输入样例
5
1
2
1
0
输出样例
2
4
5
3
1
题解
先手造一组数据
2 1 5 4 3 // 编号序列
设比第\(i\)头牛前面比它编号小的牛的数量为\(A_i\),编号为\(B_i\)
可以发现,最后一头牛编号为3,前面有2头编号比它小的牛.因为所有编号比它小的点都在前面,所以,\(B_N=A_N+1\)
同理,对于倒数第二头牛
- 若\(A_{N-1}<A_N\),则\(B_{N-1}=A_{N-1}+1\),唯一在它后面的第\(N\)头牛编号比它大,所以所有编号比它小的点都在前面,例如 :
3 4 2 1 5 // 编号序列
因为\(0=A_4<A_5=4\),则\(B_4=A_4+1=0+1=1\)
- 若\(A_{N-1}>A_N\),则\(B_{N-1}=A_{N-1}+2\),相比第一条,最后一头牛编号也比它小,额外加上1,例如 :
3 4 2 5 1 // 编号序列
因为\(3=A_4>A_5=0\),则\(B_4=A_4+2=3+2=5\)
因为第i头牛前面有\(A_i\)头牛编号比它小,所以\(B_i\)至少是\(A_i+1\)(也就是从第\(1\)到第\(i-1\)头牛都在这头牛的前面的情况),如果后面的牛还有比它小的,那么这头牛的编号又要增加,所以\(B_i\)为\(1..N\)中去掉\(B_{i+1}\)..\(B_N\)中的数 后 从前往后的第\(A_i+1\)个数
建立一个长度为\(N\)的数组c,初始化为\(1\)
因为要去掉后面的数,所以从后往前扫描\(A_i\),对于每个\(A_i\),查询该数组中第\(A_i+1\)个"1"的位置,此位置的下标就是\(B_i\),然后\(c[B_i]=0\),这是在去掉\(B_{i+1}\)..\(B_N\)中的数
使用样例数据模拟一遍
0 1 2 1 0 // A序列(省略A[0])
开始扫描
1 1 1 1 1 // c数组(省略c[0])
第一次 : \(A_5=0\),第\(0+1\)个"1"的下标为\(1\),则\(B_5=1\)
[0]1 1 1 1 // c数组(省略c[0])
第二次 : \(A_4=1\),第\(1+1\)个"1"的下标为\(3\),则\(B_4=3\)
0 1[0]1 1 // c数组(省略c[0])
第三次 : \(A_3=2\),第\(2+1\)个"1"的下标为\(5\),则\(B_3=5\)
0 1 0 1[0] // c数组(省略c[0])
第四次 : \(A_2=3\),第\(3+1\)个"1"的下标为\(4\),则\(B_2=4\)
0 1 0[0]0 // c数组(省略c[0])
第五次 : \(A_1=0\),第\(0+1\)个"1"的下标为\(2\),则\(B_1=2\)
将B数组顺序输出出来即可
至于怎么求第\(A_i+1\)个"1",就需要使用树状数组维护c数组的前缀和,每次查询时使用二分
代码
// Memory :704 KB
// Time :94 MS
// Code Length :965 B
#include <cstdio>
#include <iostream>
#define lowbit(x) ((x)&(-x))
using namespace std;
const int N = 8005;
int n, a[N], c[N], h[N];
void add(int x) {
while (x <= n) {
c[x]--;
x += lowbit(x);
}
}
int ask(int x) {
int ans = 0;
while (x) {
ans += c[x];
x -= lowbit(x);
}
return ans;
}
int main() {
scanf("%d",&n);
for (int i = 1; i <= n; i++) {
// 初始化树状数组
c[i]++;
if (i + lowbit(i) <= n) c[i + lowbit(i)] += c[i];
}
a[1] = 1; // 本来为0,提前加1
for (int i = 2; i <= n; i++) {
scanf("%d", &a[i]);
a[i]++; //提前加1
}
for (int i = n; i; i--) {
// 二分
int l = 1, r = n;
while (l < r) {
int mid = (l + r) >> 1;
if (ask(mid) < a[i]) l = mid + 1;
else r = mid;
}
// 记录答案,并更新树状数组
add(h[i] = l);
}
for (int i = 1; i <= n; i++) printf("%d\n", h[i]);
return 0;
}
POJ2182 Lost Cows 题解的更多相关文章
- [poj2182] Lost Cows (线段树)
线段树 Description N (2 <= N <= 8,000) cows have unique brands in the range 1..N. In a spectacula ...
- [BZOJ 1652][USACO 06FEB]Treats for the Cows 题解(区间DP)
[BZOJ 1652][USACO 06FEB]Treats for the Cows Description FJ has purchased N (1 <= N <= 2000) yu ...
- POJ2182 Lost Cows
题意 Language:Default Lost Cows Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 13448 Accep ...
- poj2186 Popular Cows 题解——S.B.S.
Popular Cows Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 29642 Accepted: 11996 De ...
- Poj2182 Lost Cows(玄学算法)
题面 Poj 题解 不难发现最后一位就是\(pre[n]+1\),然后消除这个位置对其他位置的贡献,从左到右扫一遍,必定有至少一个位置可以得出,循环这个过程,\(O(n^2)\)出解. #includ ...
- 洛谷 SP740 TRT - Treats for the Cows 题解
SP740 TRT - Treats for the Cows 题目描述 FJ has purchased N (1 <= N <= 2000) yummy treats for the ...
- 洛谷 P2858 [USACO06FEB]奶牛零食Treats for the Cows 题解
P2858 [USACO06FEB]奶牛零食Treats for the Cows 题目描述 FJ has purchased N (1 <= N <= 2000) yummy treat ...
- 洛谷 P3088 [USACO13NOV]挤奶牛Crowded Cows 题解
P3088 [USACO13NOV]挤奶牛Crowded Cows 题目描述 Farmer John's N cows (1 <= N <= 50,000) are grazing alo ...
- poj2182 Lost Cows[BIT二分]
blog题解鸽了许久了..本来说好的切一题写一个题解的说 一个$1 \sim n$数列,已知每个数前面比他小的数个数,试确定该序列. 相当的一道水题.可以发现数列最后一个数是首先可以确定下来的.然后把 ...
随机推荐
- (Win10)Java,Maven,Tomcat8.0,Mysql8.0.15安装与环境配置,以及IDEA2019.3使用JDBC连接MySQL、创建JavaEE项目
之前用windows+linux的双系统,最近不怎么舒服就把双系统给卸了,没想到除了问题,导致有linux残余,于是就一狠心重装了电脑,又把Java及其相关的一些东西重新装了回来,还好当初存了网盘链接 ...
- 7-6 jmu_python_最大公约数&最小公倍数 (10 分)
本题要求从键盘输入两个整数(以逗号间隔),编程求出这两个数的最大公约数和最小公倍数 提示:求最大公约数可用辗转相除法,最小公倍数用两数的积除以最大公约数 输入格式: 在一行中输入两个整数,以逗号间隔 ...
- p标签内不能嵌套块级标签
今天突然发现一个问题,那就是p标签内不能嵌套块级标签 例如: <p><p></p></p> 会被浏览器解析成 我又把 div 嵌套在里面,发现还是这样 ...
- JZOJ 5258. 友好数对 (Standard IO)
5258. 友好数对 (Standard IO) Time Limits: 1000 ms Memory Limits: 524288 KB Detailed Limits Description I ...
- Python爬虫 - UserAgent列表
PC端: PC_USER_AGENT = [ 'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)', 'Mozilla/4.0 (compatibl ...
- 盘点Linux运维常用工具(一)-web篇之httpd
#前言:想把自己学的各种服务进行分类归档起来,于是就写了盘点Linux运维常用工具,Linux方面使用到的web应用服务有httpd(apache).nginx.tomcat.lighttpd,先了解 ...
- git的日常使用(补课)
使用git的一些反响 如果在github上做一个仓库来使用的话... 首先手动在github上创建一个空的仓库,默认没有任何东西的 使用git的命令 git pull 创建的github仓库地址 能把 ...
- 【图文+视频新手也友好】Java一维数组详细讲解(内含练习题答案+详解彩蛋喔~)
目录 视频讲解: 一.数组的概述 二.一维数组的使用 三.Arrays工具类中的sort方法(sort方法用的多,我们具体讲一下) 四.数组中的常见异常 五.一维数组练习题 六.彩蛋(本期视频使用的P ...
- Spark实战--寻找5亿次访问中,访问次数最多的人
问题描述 对于一个大型网站,用户访问量尝尝高达数十亿.对于数十亿是一个什么样的概念,我们这里可以简单的计算一下.对于一个用户,单次访问,我们通常会记录下哪些数据呢? 1.用户的id 2.用户访问的时间 ...
- 简单认识并使用JavaScript【供后端人员作为了解】
JS(JavaScript)Web的脚本语言 脚本语言:无法独立执行,必须嵌入到其他语言当中结合使用 作用:控制页面特效展示 注:JavaScript没有访问系统的权限,并且JavaScript和Ja ...