Revolving Digits(hdu4333)
Revolving Digits
Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 24215 Accepted Submission(s): 5268
For each test cases, there is only one line that is the original integer N. we will ensure that N is an positive integer without leading zeros and N is less than 10^100000.
1 #include<stdio.h>
2 #include<algorithm>
3 #include<iostream>
4 #include<string.h>
5 #include<stdlib.h>
6 #include<math.h>
7 #include<cstdio>
8 #include<queue>
9 #include<stack>
10 #include<map>
11 char tt[2*100005];
12 int extend[2*100005];
13 int nex[100005];
14 char d[100005];
15 char cc[100005];
16 int pp[100005];
17 void next1(int k);
18 void EXkmp(int k,int r);
19 using namespace std;
20 int main(void)
21 {
22 int i,j,k,p,q;
23 scanf("%d",&k);
24 for(int s =1; s<=k; s++)
25 {
26 memset(nex,0,sizeof(nex));
27 memset(extend,0,sizeof(extend));
28 scanf("%s",d);
29 int l=strlen(d);
30 for(i=1; i<=2*l; i++)
31 {
32 if(i<=l)
33 tt[i]=d[i-1];
34 else
35 tt[i]=d[i-l-1];
36 }
37 for(i=0; i<l; i++)
38 cc[i+1]=d[i];
39 j=0;
40 pp[0]=0;
41 pp[1]=0;
42 for(i=2; i<=l; i++)
43 {
44 while(j>0&&cc[j+1]!=cc[i])
45 {
46 j=pp[j];
47 }
48 if(cc[j+1]==cc[i])
49 {
50 j++;
51 }
52 pp[i]=j;
53 }
54 int temp=l/(l-pp[l]);
55 if(l%(l-pp[l])!=0)
56 {
57 temp=1;
58 }
59 next1(l);
60 EXkmp(2*l,l);
61 int a[4];
62 memset(a,0,sizeof(a));
63 for(i=1; i<=l+1; i++)
64 {
65 if(extend[i]==l)//当匹配数等于l时就相等
66 {
67 a[1]++;
68 }
69 else
70 {
71 if(tt[i+extend[i]]-'0'>cc[extend[i]+1]-'0')//不等于l时比较开始不相等的那位
72 {
73 a[0]++;
74 }
75 else a[2]++;
76 }
77 }
78 printf("Case %d: ",s);
79 printf("%d %d %d\n",a[2]/temp,(a[1]-1)/temp,a[0]/temp);
80
81 }
82
83 }
84 void next1(int k)
85 {
86 int i,j,p;
87 j=1;
88 int r=j;
89 nex[1]=0;
90 while(cc[j+1]==cc[j]&&j+1<=k)
91 {
92 j++;
93 }
94 nex[2]=j-r;
95 int id=2;
96 for(i=3; i<=k; i++)
97 {
98 p=id+nex[id]-1;
99 int L=nex[i-id+1];
100 int c=i+L-1;
101 if(c>=p)
102 {
103 int j=p-i+1;
104 if(j<0)j=0;
105 while(cc[j+1]==cc[j+i]&&j+i<=k)
106 {
107 j++;
108 }
109 nex[i]=j;
110 id=i;
111 }
112 else nex[i]=L;
113 }
114 }
115
116 void EXkmp(int k,int r)
117 {
118 int i,j;
119 j=0;
120 while(cc[j+1]==tt[j+1]&&j+1<=r)
121 {
122 j++;
123 }
124 extend[1]=j;
125 int id=1;
126 int p;
127 for(i=2; i<=k; i++)
128 {
129 p=id+extend[id]-1;
130 int L=nex[i-id+1];
131 int c=i+L-1;
132 if(c>=p)
133 {
134 j=p-i+1;
135 j=max(j,0);
136 while(cc[j+1]==tt[j+i]&&j+i<=k&&j<=r)
137 {
138 j++;
139 }
140 extend[i]=j;
141 id=i;
142 }
143 else extend[i]=L;
144 }
145 }
Revolving Digits(hdu4333)的更多相关文章
- 【HDU4333】Revolving Digits(扩展KMP+KMP)
Revolving Digits Description One day Silence is interested in revolving the digits of a positive i ...
- HDU - 4333 :Revolving Digits (扩展KMP经典题,问旋转后有多少个不同的数字小于它本身,等于它本身,大于它本身。)
One day Silence is interested in revolving the digits of a positive integer. In the revolving operat ...
- HDU - 4333 Revolving Digits(扩展KMP)
http://acm.hdu.edu.cn/showproblem.php?pid=4333 题意 一个数字,依次将第一位放到最后一位,问小于本身的数的个数及等于本身的个数和大于本身的个数,但是要注意 ...
- HDU - 4333 Revolving Digits(拓展kmp+最小循环节)
1.给一个数字字符串s,可以把它的最后一个字符放到最前面变为另一个数字,直到又变为原来的s.求这个过程中比原来的数字小的.相等的.大的数字各有多少. 例如:字符串123,变换过程:123 -> ...
- Revolving Digits(hdu 4333)
题意:就是给你一个数字,然后把最后一个数字放到最前面去,经过几次变换后又回到原数字,问在这些数字中,比原数字小的,相等的,大的分别有多少个.比如341-->134-->413-->3 ...
- CodeForces 489C Given Length and Sum of Digits... (贪心)
Given Length and Sum of Digits... 题目链接: http://acm.hust.edu.cn/vjudge/contest/121332#problem/F Descr ...
- Codeforces 915 C. Permute Digits (dfs)
题目链接:Permute Digits 题意: 给出了两个数字a,b(<=1e18),保证a,b都不带前缀0.用a的字符重组一个数字使这个值最大且小于b.(保证这个值存在) 题解: 这题遇到了不 ...
- CodeForces 489C Given Length and Sum of Digits... (dfs)
C. Given Length and Sum of Digits... time limit per test 1 second memory limit per test 256 megabyte ...
- UVA-10061 How many zero's and how many digits ? (数论)
题目大意:让求n!在base进制下的位数以及末尾0的连续个数. 题目分析:一个m位的b进制数N,最小是b^(m-1),最大不超过b^m,即b^(m-1)≤N<b^m.解不等式,得log10(N) ...
随机推荐
- Prometheus_exporter安装与使用
Promethues概述:可以看一下更详细的介绍,以下为转载的博客,原文链接,支持原创,请多多支持!!:闫世成的博客园 Prometheus-node-exporter 1.简介: 内核公开的硬件和操 ...
- LeetCode一维数组的动态和
一维数组的动态和 题目描述 给你一个数组 nums.数组「动态和」的计算公式为:runningSum[i] = sum(nums[0]...nums[i]). 请返回 nums 的动态和. 示例 1: ...
- 【AWS】【TroubleShooting】EC2实例无法使用SSH远程登陆(EC2 failure for SSH connection)
1. Login AWS web console and check the EC2 instance.
- LinkBinTree
package ch11; import java.util.ArrayList; import java.util.List; import java.util.Stack; public clas ...
- 3.0 rust 项目路径
$ rustc --versionrustc 1.44.0 (49cae5576 2020-06-01) 将代码存在到不同的文件 main.rs mod aa; fn main() { println ...
- 什么是javaScript闭包
闭包是与函数有着紧密的关系,它是函数的代码在运行过程中的一个动态环境,是一个运行期的概念. 所谓闭包,是指词法表示包括不必计算的变量的函数.也就是说,该函数能够使用函数外定义的变量. 在程序语言中,所 ...
- 使用CORS处理跨域请求
package com.leyou.gateway.config;import org.springframework.context.annotation.Bean;import org.sprin ...
- 【Linux】【RedHat】下载 安装 注册
RedHat 下载 安装 注册 记录 因为找入口太麻烦了,所以写了篇博文记录下来大致入口@萌狼蓝天 注册 点击进入注册地址(https://www.redhat.com/wapps/ugc/regis ...
- MySQL5.7安装教程(亲测有效)
跟着狂神学java到了数据库阶段了,首先得安装好数据库啊,这里用的是MySQL 压缩包下载:https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5. ...
- Tableau如何绘制多边形地图
一.把省\自治区拖拽至标记生成地图二.把销售额拖拽至标记 三.地图-地图层-冲蚀100% 四.最终结果如图所示