转载自:http://blog.csdn.net/sdj222555/article/details/6878651

反素数拓展参照:http://blog.csdn.net/ACdreamers/article/details/25049767

题目大意就是一群熊孩子做游戏,第一个出队的人是编号为k的人。此后出队的人就是按照前一个人手里的编号。如果是正数+m就是这个人的左边的第m个人。如果是负数-m,就是 这个人的右边第m个人。由于这个人出队了。对下一个人有影响,所以+m的时候,是k+m-1。-m的时候是k+m。因为是他后边的人所以没有影响。因为可能出现负数和0的情况,所以就有下面的取模时的处理。线段树的每个节点保存的是这个区间还有多少个位置。所以每次更新时,如果左孩子节点的空位够了,搜索左孩子,否则搜索右孩子。可以建树参照对样例模拟一下。

还不懂怎么打反素数表。所以是cooy的。

附代码:

 #include <stdio.h>
#include <string.h>
#include <iostream>
using namespace std; #define lson l, m, rt<<1
#define rson m+1, r, rt<<1|1
#define N 500010 int tree[N<<]; const int antiprime[] = { // 反素数表
,,,,,,,,,,,,,,,
,,,,,,,,,
,,,,,,,,
,,,,
}; const int factorNum[] = { // 对应的约数个数
,,,,,,,,,,,,,,,,,,,
,,,,,,,,,,,,,,
,,,
}; struct child{ // 保存输入时的节点信息
char name[];
int val;
}c[N]; void Build(int l, int r, int rt) { // 建树
tree[rt] = r-l+;
if (l == r)
return;
int m = (l+r)>>;
Build(lson);
Build(rson);
} int Update(int p, int l, int r, int rt) { // 第p个人出去。Update函数可以理解。
tree[rt]--;
if (l == r)
return r;
int m = (l+r)>>;
if (p<=tree[rt<<])
return Update(p, lson);
else return Update(p-tree[rt<<], rson);
} int main() {
int i, n, &mod = tree[];
// mod 保存的就是一共有多少个人、
int k; while(~scanf("%d%d", &n, &k)) {
// 输入建树
for (i=; i<=n; ++i) {
scanf("%s%d", c[i].name, &c[i].val);
}
Build(, n, ); // 小于等于n的最大的反素数。
int cnt = ;
while(cnt < && antiprime[cnt] <= n) {
cnt++;
}
cnt--;
// 先找到1-n范围内的约束个数最大的数。 // pos是记录当前位置该出队的人的ID
int pos = ;
c[pos].val = ; // 找antiprime[cnt]出队的人的名字、
for (i=; i<antiprime[cnt]; ++i) { // 循环的次数就是直到这个人出队。 // 这两个if是根据 这个人手里牌的编号来推算下一个出队列的人的当前位置、
if (c[pos].val > )
k = ((k+c[pos].val-)%mod+mod)%mod+;
else k=((k+c[pos].val-)%mod+mod)%mod+; // pos 记录的是当前循环出队的人的所在位置、
pos = Update(k, , n, );
cout << pos << "====\n";
}
printf("%s %d\n", c[pos].name, factorNum[cnt]);
}
return ;
}

POJ 2886 线段树单点更新的更多相关文章

  1. poj 2828(线段树单点更新)

    Buy Tickets Time Limit: 4000MS   Memory Limit: 65536K Total Submissions: 18561   Accepted: 9209 Desc ...

  2. POJ 2828 (线段树 单点更新) Buy Tickets

    倒着插,倒着插,这道题是倒着插! 想一下如果 Posi 里面有若干个0,那么排在最前面的一定是最后一个0. 从后往前看,对于第i个数,就应该插在第Posi + 1个空位上,所以用线段树来维护区间空位的 ...

  3. poj 2886 线段树的更新+反素数

    Who Gets the Most Candies? Time Limit: 5000 MS Memory Limit: 0 KB 64-bit integer IO format: %I64d , ...

  4. POJ 2828 线段树单点更新 离线搞

    Description Railway tickets were difficult to buy around the Lunar New Year in China, so we must get ...

  5. poj 2892---Tunnel Warfare(线段树单点更新、区间合并)

    题目链接 Description During the War of Resistance Against Japan, tunnel warfare was carried out extensiv ...

  6. POJ 1804 Brainman(5种解法,好题,【暴力】,【归并排序】,【线段树单点更新】,【树状数组】,【平衡树】)

    Brainman Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 10575   Accepted: 5489 Descrip ...

  7. POJ.3321 Apple Tree ( DFS序 线段树 单点更新 区间求和)

    POJ.3321 Apple Tree ( DFS序 线段树 单点更新 区间求和) 题意分析 卡卡屋前有一株苹果树,每年秋天,树上长了许多苹果.卡卡很喜欢苹果.树上有N个节点,卡卡给他们编号1到N,根 ...

  8. POJ.2299 Ultra-QuickSort (线段树 单点更新 区间求和 逆序对 离散化)

    POJ.2299 Ultra-QuickSort (线段树 单点更新 区间求和 逆序对 离散化) 题意分析 前置技能 线段树求逆序对 离散化 线段树求逆序对已经说过了,具体方法请看这里 离散化 有些数 ...

  9. HDU 1754 I Hate It 线段树单点更新求最大值

    题目链接 线段树入门题,线段树单点更新求最大值问题. #include <iostream> #include <cstdio> #include <cmath> ...

随机推荐

  1. ubuntu下转换flv格式为mp4格式

    一.环境 ubuntu 16.04 二.安装工具 sudo apt install libav-tools 三.开始转换 avconv -i input.flv -codec copy output. ...

  2. CodeForces 1105E

    题目链接 std:meet in the middle 首先把所有的点分成两部分,设\(f_i\)为前半部分在点集\(i\)中选出的最大独立集,\(g\)为在后半部分选.这个可以在\(O(2^{m/2 ...

  3. MVC ---- 理解学习Func用法

    //Func用法 public static class FuncDemo{ public static void TestFunc(){ //数据源 List<User> usList ...

  4. python闭包closure

    在讨论闭包之前,先总结一下python的命名空间namespace,一般的语言都是通过namespace来识别名字标识,无论是变量,对象,函数等等.python划分3个名字空间层次,local:局部, ...

  5. Java东西太多,记录一些知识点

    实习两个月了,这两个月接触了不少东西,简单列举一下知识,未来需要多多学习和了解. 1.前端js.extjs4.Jquery(js框架这些基本现学现用): 2.基础不好要补补Servlet和JSP(再往 ...

  6. 对Tomcat启动或运行时,项目对jar包依赖路径的一些粗浅认知

    Tomcat在运行webapp项目的时候,需要各种依赖jar包.它会从2个地方去找这些包 1.Tomcat自己的lib目录中 2.webapp目录下,webapps\{项目}\WEB-INF\lib ...

  7. Linux——系统引导流程学习简单笔记

    开启电源: 固件 firmware(CMOS/BIOS) → POST 加电自检 对硬件就行检查 ↓ 自举程序 BootLoader(GRUB) → 载入内核 ↓ 载入内核 Kernel 1:驱动硬件 ...

  8. robot_pose的类型

    http://docs.ros.org/api/geometry_msgs/html/msg/Pose.html

  9. python 删除元组元素

    #create a tuple tuplex = "w", "j" ,"c", "e" print(tuplex) #t ...

  10. Flutter学习笔记(三)-- 事件交互和State管理

    先来看看准备界面: image.png 目标是修改图中红色实线框中的喜欢和不喜欢的五角星的修改,以及数字的修改. 在修改之前,有必要先了解一些相关的信息. 知识点 前面简单的提到过,有些Widget是 ...