Revolving Digits(hdu 4333)
题意:就是给你一个数字,然后把最后一个数字放到最前面去,经过几次变换后又回到原数字,问在这些数字中,比原数字小的,相等的,大的分别有多少个。比如341-->134-->413-->341,所以和原数字相比,比原数字小的有一个,相等的有一个,大的有一个。
/*
如果比较两个字符串,就比较第一位不一样的,那我们就需要找出所有字符串和已知字符串的前缀公共部分。
在已知字符串后面载copy一份,然后做exkmp就行了。
需要注意的是,相同字符串只能出现一次,所以先求一遍循环节。
有一篇关于exkmp的ppt:http://wenku.baidu.com/view/79992a90bed5b9f3f80f1c16.html?from=search
*/
#include<cstdio>
#include<iostream>
#include<cstring>
#define N 200100
using namespace std;
int Next[N],cas;
char T[N];
void kmp(int m){
int i=,j=-;
Next[i]=-;
while(i<m){
if(j==-||T[i]==T[j]){
i++;j++;Next[i]=j;
}
else j=Next[j];
}
}
void get_Next(){
int a=,Tlen=strlen(T);
Next[]=Tlen;
while(a<Tlen-&&T[a]==T[a+])a++;
Next[]=a;
a=;
for(int k=;k<Tlen;k++){
int p=a+Next[a]-,L=Next[k-a];
if(k-+L>=p){
int j=(p-k+>)?p-k+:;
while(k+j<Tlen&&T[k+j]==T[j])j++;
Next[k]=j;
a=k;
}
else Next[k]=L;
}
}
int main(){
int t;scanf("%d",&t);
while(t--){
scanf("%s",T);
int len=strlen(T);
kmp(len);
int k=len-Next[len],tt;
if(len%k==)tt=len/k;
else tt=;
for(int i=;i<len;i++) T[len+i]=T[i];
get_Next();
int num1=,num2=,num3=;
for(int i=;i<len;i++){
if(Next[i]>=len)num2++;
else if(T[Next[i]]>T[i+Next[i]])num1++;
else if(T[Next[i]]<T[i+Next[i]])num3++;
}
printf("Case %d: %d %d %d\n",++cas,num1/tt,num2/tt,num3/tt);
}
return ;
}
Revolving Digits(hdu 4333)的更多相关文章
- HDU - 4333 Revolving Digits(扩展KMP)
		
http://acm.hdu.edu.cn/showproblem.php?pid=4333 题意 一个数字,依次将第一位放到最后一位,问小于本身的数的个数及等于本身的个数和大于本身的个数,但是要注意 ...
 - 2道acm编程题(2014):1.编写一个浏览器输入输出(hdu acm1088);2.encoding(hdu1020)
		
//1088(参考博客:http://blog.csdn.net/libin56842/article/details/8950688)//1.编写一个浏览器输入输出(hdu acm1088)://思 ...
 - HDU - 4333 :Revolving Digits (扩展KMP经典题,问旋转后有多少个不同的数字小于它本身,等于它本身,大于它本身。)
		
One day Silence is interested in revolving the digits of a positive integer. In the revolving operat ...
 - 【HDU4333】Revolving Digits(扩展KMP+KMP)
		
Revolving Digits Description One day Silence is interested in revolving the digits of a positive i ...
 - Revolving Digits(hdu4333)
		
Revolving Digits Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
 - Bestcoder13  1003.Find Sequence(hdu 5064) 解题报告
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5064 题目意思:给出n个数:a1, a2, ..., an,然后需要从中找出一个最长的序列 b1, b ...
 - 2013 多校联合 F Magic Ball Game (hdu 4605)
		
http://acm.hdu.edu.cn/showproblem.php?pid=4605 Magic Ball Game Time Limit: 10000/5000 MS (Java/Other ...
 - Maximum Sum of Digits(CodeForces 1060B)
		
Description You are given a positive integer nn. Let S(x) be sum of digits in base 10 representation ...
 - (多线程dp)Matrix (hdu 2686)
		
http://acm.hdu.edu.cn/showproblem.php?pid=2686 Problem Description Yifenfei very like play a num ...
 
随机推荐
- vue.js之绑定class和style
			
一.绑定Class属性. 绑定数据用v-bind:命令,简写成: 语法:<div v-bind:class="{ active: isActive }"></di ...
 - bzoj3110
			
3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 5881 Solved: 1958[Submit][Sta ...
 - Ubuntu/mint清理系统垃圾
			
Ubuntu Linux与Windows系统不同,Ubuntu Linux不会产生无用垃圾文件,但是在升级缓存中,Ubuntu Linux不会自动删除这些文件,今天就来说说这些垃圾文件清理方法. 1 ...
 - bzoj4458: GTY的OJ
			
题目大意:给定一棵带点权的有根树,同时给定L,R,要求找M条链,每条链满足以下条件的情况下,要求所有链权和最大: 1.两两不相同(可以包含/相交等) 2.节点数在[L,R]间 3.其中一个端点的深度必 ...
 - 【BZOJ-2730】矿场搭建     Tarjan 双连通分量
			
2730: [HNOI2012]矿场搭建 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1602 Solved: 751[Submit][Statu ...
 - 为自己的爬虫更换代理和HTML头部
			
import requestsimport reimport randomimport time class download(): def __init__(self): self.iplist = ...
 - 用PHPstorm同步服务器文件断开连接
			
使用同步功能,PHPstorm好像会一个一个去对比服务器上的文件,导致频繁请求建立连接,服务器本地安全策略做了屏蔽,所以进入黑名单后就无法连接了
 - 关于 DataGridTextColumn的IsReadOnly
			
1. 以下是绑定方式,但是IsReadOnly不起作用 <DataGrid x:Name="dgTest" ItemsSource="{Binding}" ...
 - 【Beta】第5.5次任务发布
			
PM #100 日常管理&dev版宣传&设计报告管理后台. 后端 #101 完成收藏功能 完成管理员权限表的生成和接入(按位压缩权限表) 验收条件:收藏功能能够正常使用.能够区分常规用 ...
 - ionic ios 友盟多渠道/自动签名/加固之腾讯云。乐固
			
之前写了一篇文章主要是介绍使用gradle进行多渠道分发处理的文章--链接:http://www.cnblogs.com/happen-/p/6029387.html 最近在做app上线的处理,发现某 ...