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

 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. VS2010调试多进程--医疗His调试中使用

    有些时候碰到自己开发的程序嵌入到别人的框架中,而在接口的地方出了问题,而又不方便将自己的模快加入到别人的工程中这个时候VS的附加到进程调试变得不可或缺了,直奔主题 http://msdn.micros ...

  2. js中 的这些距离你知道吗?

  3. java的真相

    所谓编译,就是把源代码“翻译”成目标代码——大多数是指机器代码——的过程.针对Java,它的目标代码不是本地机器代码,而是虚拟机代码. 编译原理里面有一个很重要的内容是编译器优化.所谓编译器优化是指, ...

  4. Asp.net: WebForm基础上构建Mvc的方法

    添加引用: System.Web.Routing System.Web.Abstractions System.Web.Mvc 添加文件夹: Controllers, Views,  Views / ...

  5. Android占位符

    <xliff:g>标签介绍: 属性id可以随便命名 属性值举例说明%n$ms:代表输出的是字符串,n代表是第几个参数,设置m的值可以在输出之前放置空格 %n$md:代表输出的是整数,n代表 ...

  6. 谷歌的C++智能指针实现

    //智能指针基类所有智能指针对象都继承该类class RefCountedBase { public: ; ; protected: virtual ~RefCountedBase(){} }; 智能 ...

  7. Listview控件实现已选择效果

    Winform中用Listview控件实现更新点击选择后已选择效果,如图: 代码如下: private void frmSelect_Load(object sender, EventArgs e) ...

  8. [CSS]text-decoration

      定义和用法 text-decoration 属性规定添加到文本的修饰. 可能的值 值 描述 none 默认.定义标准的文本. underline 定义文本下的一条线. overline 定义文本上 ...

  9. PHP文件上传与安全

    文件上传的流程 上传必须由POST方式的file类型表单提交,被提交的地方 一定是一个php程序,用户在表单使用file类型的域.选在一个自己电脑上的文件,提交到php程序以后 其实就已经完成了一个上 ...

  10. PyQt5创建第一个窗体(正规套路)

    一.Pyqt5 创建第一个窗体 很多人写窗体程序都是直接敲代码,不使用设计器,我个人不是很赞成这种做法.使用设计器的好处是直观.维护方便,尤其开发复杂窗体的效率高. 但是每次修改ui文件后,需要重新生 ...