首页 > 其他分享 >POJ2886线段树 Joseph游戏(单点更新)

POJ2886线段树 Joseph游戏(单点更新)

时间:2023-05-31 18:37:28浏览次数:56  
标签:rt 单点 int tree pos Joseph 区间 POJ2886 mod


题目:Who Gets the Most Candies?

 

题意:

1.n个人进行Joseph游戏,游戏共p轮(p为 思路:用相对坐标来处理,例如这一轮出局的是p,下一个要+m,则p出局时p+1就变成了p(因为是相对

坐标),则下一个人应该是p+m-1,再注意循环和m的正负的处理,不要忘了取模。

2.求解原始序号时维护一棵线段树,类似上一题插队的方法建树,每个节点为该区间段的人数,则要在(l,r)区间踢出第p个人,若p小于等于tree[rt<<1],则在

左半区间踢第p个人,否则在右半区间踢第(p-tree[rt<<1])个人(tree[rt<<1]为左半区间人数),如此向下处理,直到踢出该人。

#include <stdio.h>

#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1

#define N 500010

int tree[N<<2];

const int antiprime[]={1,2,4,6,12,24,36,48,60,120,180,240,360,720,840,
                       1260,1680,2520,5040,7560,10080,15120,20160,25200,
                       27720,45360,50400,55440,83160,110880,166320,221760,
                       277200,332640,498960,554400,665280
                      };

const int factorNum[]={1,2,3,4,6,8,9,10,12,16,18,20,24,30,32,36,40,48,60,
                       64,72,80,84,90,96,100,108,120,128,144,160,168,180,
                       192,200,216,224
                      };

struct child
{
    char name[15];
    int val;
}c[N];

void Build(int l,int r,int rt)
{
    tree[rt]=r-l+1;
    if(l==r)
        return;
    int m=(l+r)>>1;
    Build(lson);
    Build(rson);
}

int Update(int p,int l,int r,int rt)
{
    tree[rt]--;
    if(l==r)
         return r;
    int m=(l+r)>>1;
    if(p<=tree[rt<<1])
         return Update(p,lson);
    return Update(p-tree[rt<<1],rson);
}

int main()
{
    int i,n,k,&mod=tree[1];
    while(~scanf("%d%d",&n,&k))
    {
        for(i=1;i<=n;i++)
            scanf("%s%d",c[i].name,&c[i].val);
        Build(1,n,1);
        int cnt=0;
        while(cnt<35 && antiprime[cnt]<=n)
            cnt++;
        cnt--;
        int pos=0;
        c[pos].val=0;
        for(i=0;i<antiprime[cnt];i++)
        {
            if(c[pos].val>0)
                k=((k+c[pos].val-2)%mod+mod)%mod+1;
            else
                k=((k+c[pos].val-1)%mod+mod)%mod+1;
            pos=Update(k,1,n,1);
        }
        printf("%s %d\n",c[pos].name,factorNum[cnt]);
    }
    return 0;
 }



标签:rt,单点,int,tree,pos,Joseph,区间,POJ2886,mod
From: https://blog.51cto.com/u_16146153/6388744

相关文章

  • asm单点安装(库神支持)
    感谢库神支持1、unzipLINUX.X64_19300_grid_home.zip-d$ORACLE_HOME(grid)chown-Rgrid:oinstall/app/softchown-Rgrid:asmadmin/dev/asm1vi/app/soft/install/response/gridsetup.rsp2、编辑grid_install.rsp配置文件oracle.install.responseFileVersion=/oracle/i......
  • 单点登录
    1、概念单点登录SSO,说的是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信任。2、单点登录的要点存储信任;验证信任;3、实现单点登录的三种方式(1)以cookie作为凭证最简单的单点登录实现方式,是使用cookie作为媒介,存......
  • 单点登录 XXL sso-client sso-server
    单点登录一处登陆处处使用环境配置gulimall-test-sso-clientgulimall-test-sso-server127.0.0.1ssoserver.com127.0.0.1client1.com127.0.0.1client2.comgulimall-test-sso-server中设置登陆@GetMapping("/login.html")publicStringloginPage(@RequestPara......
  • 单点登陆社交登陆
    单点登陆社交登陆OAuth2.0OAuth2.0使用微博社交登陆https://open.weibo.com/connect开发手册https://open.weibo.com/wiki/%E6%8E%88%E6%9D%83%E6%9C%BA%E5%88%B6%E8%AF%B4%E6%98%8E更换YOUR_CLIENT_IDAppKey:1514335119更换YOUR_REGISTERED_REDIRECT_URIOAuth2......
  • 微服务使用openfeign调用单点的会话失效问题
    项目Springcloud,认证中心方式实现SSO使用开源框架Sa-Token本身的单独访问每个客户端服务的单点就没有问题。然后单点通过Fegin调用就不好使了!主要使用的Sa-Token的微服务单点功能使用的依赖如下<!--SA-TokenSSO--><dependencyManagement><dependencies>......
  • 基于轨迹预测的驾驶员方向控制方法实现的单点预瞄,通过carsim与simulink仿真发现,该方法
    基于轨迹预测的驾驶员方向控制方法实现的单点预瞄,通过carsim与simulink仿真发现,该方法能够良好的实现车俩的轨迹跟踪控制。有对应信息和文件说明。ID:23100684398458311......
  • 如何避免单点风险:基于实践经验分享服务拆分原则的一些思考
    缘起:系统崩了具体情况:1%的请求影响了剩余90%的请求架构演进:拆分热点服务【进程级隔离】复盘总结拆服务的经典实践 不能变形的变形金刚也叫变形金刚?缘起系统崩溃了?别惊慌!这里有快速恢复的方法!分析发现,网站崩时服务X被流量打垮,继而依赖服务X的其它服务开始......
  • cas单点登录-1.准备cas-server
    1、获取对应java版本的cas服务端代码GitHub-apereo/cas-overlay-template:ApereoCASWAROverlaytemplate对应的java版本为(截止2023/4/27) 根据电脑环境拉取对应分支的代码2、编译打包window:点击build.sh,或者执行命令mvncleanpackage-Dmaven.test.skip=true获取w......
  • .NET CORE开源 DDD微服务 支持 多租户 单点登录 多级缓存、自动任务、分布式、日志、
    源代码地址https://github.com/junkai-li/NetCoreKevin基于NET6搭建跨平台DDD思想WebApi架构、IDS4单点登录、多缓存、自动任务、分布式、多租户、日志、授权和鉴权、CAP、SignalR、docker部署 如需简约项目可直接去除项目引用解耦设计都可以单独引用架构默认全部引用并启动......
  • asp.net程序通过Microsoft Azure中SAML协议实现单点登录
    1.新建应用程序登录Azure门户,进入左侧菜单“企业应用程序--所有应用程序”,点“新建应用程序”,继续点“创建你自己的应用程序”,如下图选择和录入名称:填好应用的名称、想要如何处理应用程序必须选择第三个“继承未在库中找到的任何其他应用程序(非库)”,之后点“创建”按钮;2.单......