POJ2886 Who Gets the Most Candies?【线段树 点修改】

2024-01-20 14:38

本文主要是介绍POJ2886 Who Gets the Most Candies?【线段树 点修改】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Who Gets the Most Candies?

http://poj.org/problem?id=2886

Time Limit: 5000MS Memory Limit: 131072K
Total Submissions: 16835 Accepted: 5298
Case Time Limit: 2000MS

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 A is 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

There are several test cases in the input. Each test case starts with two integers N (0 < N ≤ 500,000) and K (1 ≤ K ≤ N) on the first line. The next N lines contains the names of the children (consisting of at most 10 letters) and the integers (non-zero with magnitudes within 108) on their cards in increasing order of the children’s numbers, a name and an integer separated by a single space in a line with no leading or trailing spaces.

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 2
Tom 2
Jack 4
Mary -1
Sam 1

Sample Output

Sam 3

Source

POJ Monthly--2006.07.30, Sempr

题意

 n个孩子按顺时针排列,每个人手上都有一张牌,牌上有一个数字,从第k个孩子开始出队,出队的孩子卡上数字是val,则从他开始顺时针第val人是下一个出队的,负数则逆时针数那个第val个人,第P个出队的会得到的糖果数是p的因子个数,输出得到最多糖果的人和他的糖果数,如果有多个,则输出最先出队的人。

思路

先打表求出1-500000的因子个数,然后使用线段树,点修改,区间信息为这个区间还剩下多少人。

C++代码

#include<iostream>using namespace std;#define ls l,m,rt<<1
#define rs m+1,r,rt<<1|1const int N=500050;char name[N][15];
int val[N];
int f[N];//f[i]=j,表示数i有j个因子 
int sum[N<<2];//打表求f[n] 
void maketable(int n)
{for(int i=1;i<n;i++) f[i]=1;for(int i=2;i<n;i++)for(int j=i;j<n;j+=i)f[j]++;
}int getorder(int n)
{int k=1;for(int i=2;i<=n;i++)if(f[k]<f[i])k=i;return k;
}void pushup(int rt)
{sum[rt]=sum[rt<<1]+sum[rt<<1|1];
}void build(int l,int r,int rt)
{if(l==r){sum[rt]=1;return;}int m=(l+r)>>1;build(ls);build(rs);pushup(rt);
}int update(int num,int l,int r,int rt)
{if(l==r){sum[rt]=0;return l;}int m=(l+r)>>1;int res;if(num<=sum[rt<<1])res=update(num,ls);elseres=update(num-sum[rt<<1],rs);pushup(rt);return res;
}int main()
{int n,k;maketable(N);while(~scanf("%d%d",&n,&k)){for(int i=1;i<=n;i++)scanf("%s%d",name[i],&val[i]);build(1,n,1);int order=getorder(n);//出队次序为 order 的人获得的糖果最多 int pos=0,num=k,total=n,ln=0,rn=0;for(int i=1;i<=order;i++){pos=update(num,1,n,1);total--;ln=num-1;//删除元素左边的人的数量 rn=total-num+1;//删除元素右边的人的数量if(i==order) break;//找到第order个出队的人,跳出//获取下一个出队的人是现在队列中的第num个人,即求num int v=val[pos];//v表示跳跃值 if(v>0){v%=total;if(!v) v=total;if(v<=rn)num=ln+v;elsenum=v-rn;} else{v=-v;v%=total;if(!v) v=total;if(v<=ln)num=ln-v+1;elsenum=total-v+ln+1;}}printf("%s %d\n",name[pos],f[order]); }return 0;
}

 

这篇关于POJ2886 Who Gets the Most Candies?【线段树 点修改】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/626332

相关文章

kingbase修改权限实现方式

《kingbase修改权限实现方式》该文章详细介绍了如何在数据库中创建用户并赋予其相应的权限,包括创建用户、回收默认权限、创建数据库、赋权数据库权限、创建只读用户以及回收权限等步骤... 目录前言使用步骤总结前言创建用户后对数据库对象的读写权限进行修改使用步骤1、创建用户create user cs

linux实现对.jar文件的配置文件进行修改

《linux实现对.jar文件的配置文件进行修改》文章讲述了如何使用Linux系统修改.jar文件的配置文件,包括进入文件夹、编辑文件、保存并退出编辑器,以及重新启动项目... 目录linux对.jar文件的配置文件进行修改第一步第二步 第三步第四步总结linux对.jar文件的配置文件进行修改第一步进

Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)

《Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)》在职场中,Word文档是公认的好伙伴,但你有没有被它折磨过?批量生成合同、制作报告以及发放证书/通知等等,这些重复、低效... 目录重复性文档制作,手动填充模板,效率低下还易错1.python-docx入门:Word文档的“瑞士

Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧

《Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧》本文将通过实际代码示例,深入讲解Python函数的基本用法、返回值特性、全局变量修改以及异常处理技巧,感兴趣的朋友跟随小编一起看看... 目录一、python函数定义与调用1.1 基本函数定义1.2 函数调用二、函数返回值详解2.1 有返

Nginx屏蔽服务器名称与版本信息方式(源码级修改)

《Nginx屏蔽服务器名称与版本信息方式(源码级修改)》本文详解如何通过源码修改Nginx1.25.4,移除Server响应头中的服务类型和版本信息,以增强安全性,需重新配置、编译、安装,升级时需重复... 目录一、背景与目的二、适用版本三、操作步骤修改源码文件四、后续操作提示五、注意事项六、总结一、背景与

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

Oracle修改端口号之后无法启动的解决方案

《Oracle修改端口号之后无法启动的解决方案》Oracle数据库更改端口后出现监听器无法启动的问题确实较为常见,但并非必然发生,这一问题通常源于​​配置错误或环境冲突​​,而非端口修改本身,以下是系... 目录一、问题根源分析​​​二、保姆级解决方案​​​​步骤1:修正监听器配置文件 (listener.

Linux中修改Apache HTTP Server(httpd)默认端口的完整指南

《Linux中修改ApacheHTTPServer(httpd)默认端口的完整指南》ApacheHTTPServer(简称httpd)是Linux系统中最常用的Web服务器之一,本文将详细介绍如何... 目录一、修改 httpd 默认端口的步骤1. 查找 httpd 配置文件路径2. 编辑配置文件3. 保存

Nginx 413修改上传文件大小限制的方法详解

《Nginx413修改上传文件大小限制的方法详解》在使用Nginx作为Web服务器时,有时会遇到客户端尝试上传大文件时返回​​413RequestEntityTooLarge​​... 目录1. 理解 ​​413 Request Entity Too Large​​ 错误2. 修改 Nginx 配置2.1

Python对PDF书签进行添加,修改提取和删除操作

《Python对PDF书签进行添加,修改提取和删除操作》PDF书签是PDF文件中的导航工具,通常包含一个标题和一个跳转位置,本教程将详细介绍如何使用Python对PDF文件中的书签进行操作... 目录简介使用工具python 向 PDF 添加书签添加书签添加嵌套书签Python 修改 PDF 书签Pytho