poj2886 Who Gets the Most Candies?
来源:互联网 发布:php 问答社区 编辑:程序博客网 时间:2024/05/21 10:48
Description
N children are sitting in a circle to play a game.
The children are numbered from 1 to N in clockwise order. Each of them has a card with a non-zero integer on it in his/her hand. The game starts from the K-th child, who tells all the others the integer on his card and jumps out of the circle. The integer on his card tells the next child to jump out. Let A denote the integer. If A is positive, the next child will be the A-th child to the left. If Ais negative, the next child will be the (−A)-th child to the right.
The game lasts until all children have jumped out of the circle. During the game, the p-th child jumping out will get F(p) candies where F(p) is the number of positive integers that perfectly divide p. Who gets the most candies?
Input
Output
Output one line for each test case containing the name of the luckiest child and the number of candies he/she gets. If ties occur, always choose the child who jumps out of the circle first.
Sample Input
4 2Tom 2Jack 4Mary -1Sam 1
Sample Output
Sam 3
Source
反素数+线段树,思路很好。
首先可以发现获得糖果最多的小孩的出队顺序tot是小于等于n的最大反素数。(不知道反素数的去百度…)
我选择用筛表法求反素数。(打表更快)
接下来的问题就是模拟tot次出队操作了。这里可以用线段树维护区间内还有多少个孩子没有出队,每次求出下一个孩子是第几个。(具体方法详见代码,自己画个图就理解了…)
这道题用线段树的思路很好,将寻找下一个出队位置的复杂度从O(n)降低到O(logn)。
#include<iostream>#include<cstdio>#include<cstdlib>#include<algorithm>#include<cmath>#include<cstring>#define F(i,j,n) for(int i=j;i<=n;i++)#define D(i,j,n) for(int i=j;i>=n;i--)#define LL long long#define pa pair<int,int>#define MAXN 500005using namespace std;int n,k,tot,pos,mod,f[MAXN];struct kid_type{char s[20];int val;}a[MAXN];struct tree_type{int l,r,sum;}t[MAXN*4];void build(int k,int x,int y){t[k].l=x;t[k].r=y;t[k].sum=y-x+1;if (x==y) return;int mid=(x+y)>>1;build(k<<1,x,mid);build(k<<1|1,mid+1,y);}int update(int k,int x){t[k].sum--;if (t[k].l==t[k].r) return t[k].l;if (t[k<<1].sum>=x) return update(k<<1,x);else return update(k<<1|1,x-t[k<<1].sum);}int findmax(){memset(f,0,sizeof(f));F(i,1,n) for(int j=i;j<=n;j+=i) f[j]++;int mx=0;F(i,1,n) if (f[i]>f[mx]) mx=i;return mx;}int main(){//freopen("input.in","r",stdin);a[0].val=0;while (~scanf("%d %d\n",&n,&k)){build(1,1,n);F(i,1,n) scanf("%s %d\n",a[i].s,&a[i].val);tot=findmax();pos=0;mod=n;F(i,1,tot){if (a[pos].val>0) k=((k+a[pos].val-2)%mod+mod)%mod+1;else k=((k+a[pos].val-1)%mod+mod)%mod+1;pos=update(1,k);mod--;}printf("%s %d\n",a[pos].s,f[tot]);}}
- POJ2886--Who Gets the Most Candies?
- poj2886 Who Gets the Most Candies?
- poj2886 Who Gets the Most Candies?
- POJ2886 Who Gets the Most Candies?
- poj2886 Who Gets the Most Candies?
- POJ2886-Who Gets the Most Candies?
- POJ2886:Who Gets the Most Candies?(线段树单点更新)
- poj2886-Who Gets the Most Candies?(线段树)
- 线段树:POJ2886 Who Gets the Most Candies?
- poj2886 Who Gets the Most Candies? 线段树
- poj2886--Who Gets the Most Candies?(线段树+反素数)
- poj2886 Who Gets the Most Candies? 线段树加反素数
- 【POJ2886】Who Gets the Most Candies?-线段树+反素数
- 【poj2886】Who Gets the Most Candies?——线段树
- poj2886 Who Gets the Most Candies?反素数+线段树
- POJ2886-Who Gets the Most Candies?-树状数组
- POJ2886-Who Gets the Most Candies?(反素数)
- POJ2886 Who Gets the Most Candies? 线段树+预处理
- 【VSTS 日志 15/11/18】 – 插件应用市场,RM,包管理器等
- PrimeFaces 核心源码 js
- mysql5.6常见数据类型
- 【论文笔记】DeepID人脸识别算法之三代
- OC匿名对象
- poj2886 Who Gets the Most Candies?
- JS 简单回调函数实现
- JSP基础
- JavaWeb---框架SpringMvc+Mybatis开发项目第二季(共三季)
- C语言----for语句,break和continue的应用与区别
- iOS 8中使用UIAlertController
- poj2750 Potted Flower
- 深入C语言内存区域分配(进程的各个段)详解
- 使用matlab执行mex找不到编译器