反素数范围不大,可以直接打表得
然后就是模拟移动的过程
我们可以用线段树优化,具体明天再说吧

 const op:array[..] of longint=(,,,,,,,,,,,,,,
                                 ,,,,,,,,
                                 ,,,,,,,
                                 ,,,,,);
      fac:array[..] of longint=(,,,,,,,,,,,,,,,,,
                                 ,,,,,,,,,,,,,
                                 ,,,,);
var tree:array[..] of longint;
    a:array[..] of longint;
    nam:array[..] of string[];
    p,k,i,w,h,n,m:longint;
    ch:char; procedure build(i,l,r:longint);
  var m:longint;
  begin
    if l=r then
      tree[i]:=
    else begin
      m:=(l+r) shr ;
      build(i*,l,m);
      build(i*+,m+,r);
      tree[i]:=tree[i*]+tree[i*+];
    end;
  end; procedure work(i,l,r:longint);
  var m:longint;
  begin
    if l=r then
      tree[i]:=
    else begin
      m:=(l+r) shr ;
      if k<=m then work(i*,l,m)
      else work(i*+,m+,r);
      tree[i]:=tree[i*]+tree[i*+]
    end;
  end; function sum(i,l,r:longint):longint;
  var m:longint;
  begin
    if (<=l) and (k>=r) then
      exit(tree[i])
    else begin
      m:=(l+r) shr ;
      sum:=;
      if m>= then sum:=sum+sum(i*,l,m);
      if k>m then sum:=sum+sum(i*+,m+,r);
    end;
  end; function ask(i,l,r:longint):longint;   
  var m:longint;
  begin
    if l=r then exit(l)
    else begin
      m:=(l+r) shr ;
      if w>tree[i*] then
      begin
        w:=w-tree[i*];
        exit(ask(i*+,m+,r));
      end
      else exit(ask(i*,l,m));
    end;
  end; begin
  while not eof do
  begin
    readln(n,k);
    for i:= downto do
      if (op[i]<=n) then
      begin
        p:=i;
        break;
      end;     m:=n;
    for i:= to n do
    begin
      nam[i]:='';
      read(ch);
      while ch<>' ' do
      begin
        nam[i]:=nam[i]+ch;
        read(ch);
      end;
      readln(a[i]);
    end;
    build(,,n);     for i:= to op[p]- do
    begin
      dec(m);
      work(,,n);
      if a[k]< then  //分类讨论,找下一个人
      begin
        w:=-a[k];
        h:=sum(,,n);
        if w<=h then
        begin
          w:=h-w+;
          k:=ask(,,n);
        end
        else begin
          w:=(w-h-) mod m+;
          w:=m-w+;
          k:=ask(,,n);
        end;
      end
      else begin
        w:=a[k];
        h:=sum(,,n);
        if w<=m-h then
        begin
          w:=w+h;
          k:=ask(,,n);
        end
        else begin
          w:=w-(m-h);
          w:=(w-) mod m+;
          k:=ask(,,n);
        end;
      end;
    end;
    writeln(nam[k],' ',fac[p]);
  end;
end.

poj2886的更多相关文章

  1. poj2886(线段树求序列第k小)

    题目链接:https://vjudge.net/problem/POJ-2886 题意:n个人围成一个圈,每个人有姓名s和权值val两个属性,第一轮序号为k的人退出,并根据其val指定下一个人,val ...

  2. POJ-2886 Who Gets the Most Candies?---线段树+约瑟夫环

    题目链接: https://cn.vjudge.net/problem/POJ-2886 题目大意: N个人围成一圈第一个人跳出圈后会告诉你下一个谁跳出来跳出来的人(如果他手上拿的数为正数,从他左边数 ...

  3. 【POJ2886】Who Gets the Most Candies?-线段树+反素数

    Time Limit: 5000MS Memory Limit: 131072K Case Time Limit: 2000MS Description N children are sitting ...

  4. POJ-2886 Who Gets the Most Candies?(线段树+模拟)

    题目大意:n个小孩按顺时针站成一圈,每次会有一个小孩出队(第一个出队的小孩已知),在他出队时会指定下一个出队的小孩,直到所有的小孩全部出队游戏结束.第p个出队的小孩会得到f(p)个糖果,f(p)为p的 ...

  5. POJ2886 Who Gets the Most Candies? 线段树 反素数

    题意:有一群小朋友围成一个环,编号1,2,3…N.每个人手上握着一个非0的数字,首先第K个人出列,然后看他手上的数字,假设为m,则从下一个开始第m个人出列,一直如此.并设i为小于等于N的最大反素数,问 ...

  6. 【POJ2886】【线段树】Who Gets the Most Candies?

    Description N children are sitting in a circle to play a game. The children are numbered from 1 to N ...

  7. poj2886线段树(单点修改,区间查询)

    Who Gets the Most Candies? Time Limit: 5000MS   Memory Limit: 131072K Total Submissions: 11955   Acc ...

  8. poj2886 Who Gets the Most Candies?

    思路: 先打反素数表,即可确定因子最多的那个数.然后模拟踢人的过程确定对应的人名.模拟的过程使用线段树优化加速. 实现: #include <cstdio> #include <cs ...

  9. poj分类 很好很有层次感。

    初期: 一.基本算法:      (1)枚举. (poj1753,poj2965)      (2)贪心(poj1328,poj2109,poj2586)      (3)递归和分治法.      ( ...

随机推荐

  1. CentOS隐藏nginx版本号

    在/usr/local/nginx/conf/目录中,修改nginx.conf文件 在http {  }段中加入 http { server_tokens off; }

  2. Java Post 数据请求和接收

    这两天在做http服务端请求操作,客户端post数据到服务端后,服务端通过request.getParameter()进行请求,无法读取到数据,搜索了一下发现是因为设置为text/plain模式才导致 ...

  3. json 是什么

    怎么学习一个知识? 首先要提出几个问题,目前认为json是个什么,json是谁创造的,为什么而出现的,但是目前仅有很长时间之前别人直接告诉我的,json用来存数据的,对于使用也忘记的差不多了,所以现在 ...

  4. swift 截取字符串

  5. js实现文件上传,删除效果

    效果图: 刚开始: 点击按钮"选择更多后",可以添加很多选择文件: 点击按钮"删除"后: 实现代码: <!DOCTYPE html><html ...

  6. js实现简单计算器

    效果图: 刚开始做时没考虑到清零和退格两个功能,嘻嘻,后来加的整体与传统计算器比有点小瑕疵. 代码: <!DOCTYPE html><html><head> < ...

  7. 忘记Mysql的root密码怎么办?

    解决方法: 1.打开cmd,用net start命令查看是否开启了mysql服务,如果开启,用net stop mysql 命令关闭mysql 2.进入mysql的安装目录下的bin目录,例如:E:\ ...

  8. LINUX 下mysql数据库导出

    mysqldump -u root -p dbname > db.sql

  9. JavaScript学习总结【1】、初识JS

    1.什么是 JavaScript? JavaScript 是一门跨平台.面向对象的动态的弱类型的轻量级解释型语言,是一种基于对象和事件驱动并具有相对安全性的客户端脚本语言.应用于 HTML 文档能够在 ...

  10. iOS 中KVC、KVO、NSNotification、delegate 总结及区别-b

    1.KVC,即是指 NSKeyValueCoding,一个非正式的Protocol,提供一种机制来间接访问对象的属性.而不是通过调用Setter.Getter方法访问.KVO 就是基于 KVC 实现的 ...