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

 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. Bash中的$符号

    脚本名称:$0 PID:$$ 参数个数:$# 脚本返回值:$? 第x个参数:$x 第10个以上的参数加大括号:${10} 所有参数:$@ #!/bin/bash echo "The prog ...

  2. 文件图标css样式

    .list-list .ico-bookfolder { background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEU ...

  3. hbs

    <!-- 把这个页面纳入 main 框架里面 -->{{!< main}}<link rel="stylesheet" href="/css/jq ...

  4. T-SQL中的透视和逆透视

    透视 今天抽一点时间来看看透视和逆透视语句,简单的说就是行列转换.假设一个销售表中存放着产品号,产品折扣,产品价格三个列,每一种产品号可能有多种折扣,每一种折扣只对应一个产品价格.下面贴出建表语句和插 ...

  5. 组策略彻底解决windows 2003 终端数

         win2003的话可以从组策略修改: 组策略级别要高于终端服务配置,当启用组策略后终端服务配置中的相应选项会变成灰色不可修改 运行-gpedit.msc-计算机配置-管理模板-Windows ...

  6. java动态绑定的情况分析

    java是面向对象的语言,java中多态的一种情况是动态绑定.所谓的动态绑定,分两种情况:当调用类方法的时候,java虚拟机会基于对象的引用类型来选择执行方法.当java调用一个实例方法的时候,他会根 ...

  7. List集合的去除重复性练习

    package com.java.b.listdmeo.www; import java.util.ArrayList;import java.util.Iterator; import com.ja ...

  8. Linux权限体系总结

    总结 1.  LINUX9位权限及rwx字符的作用.对应的数字及对应的用户和用户组图解. 2.  rwx对文件来说代表什么意思. 3.  rwx对目录来说代表什么意思. 4.  企业生产环境目录设置权 ...

  9. WPF 保存文件

    private void button2_Click(object sender, RoutedEventArgs e) { var saveFileDialog1 = new SaveFileDia ...

  10. CSS一级导航-天蓝色(带阴影)

    一款亮丽的导航,能给网站一个画龙点睛的作用.导航在指引用户搜寻内容时,还能改变用户浏览网站的心情,浏览网站也像一场旅行,有创意的导航栏让用户欣赏起来也会更加愉悦,增加对网站的兴趣. 本人不擅长美工制作 ...