zcmu1550(字符串最小表示法)
1550: AA
Time Limit:?1 Sec??Memory Limit:?128 MB
Submit:?125??Solved:?35
[Submit][Status][Web Board]
Description
?其實(shí)第一次聽(tīng)說(shuō)要出題目我是拒絕的,因?yàn)?#xff0c;你不能讓我出,我就馬上去出,我要試一下,因?yàn)槲也辉敢獬鐾炅艘院笤偌右恍┌咐先?#xff0c;然后題目duang的一下就被AC了。現(xiàn)在要求對(duì)字符串進(jìn)行環(huán)狀左移操作,每次向左移動(dòng)一個(gè)位置。例如:對(duì)duang進(jìn)行操作,得到的全部字符串為:
duang
uangd
angdu
ngdua
gduan
輸出得到最小字典序的字符串的最小移動(dòng)次數(shù)。
Input
輸入一個(gè)數(shù)T(1<=T<=100),表示接下來(lái)有T行字符串;輸入字符串S,S的長(zhǎng)度為L(zhǎng)(5<=l<=100000)。
Output
輸出一個(gè)數(shù)字,表示為得到最小字典序的字符串的最小移動(dòng)次數(shù)。
Sample Input
2
baabaa
alabala
Sample Output
1
6
解析:這道題考的就是字符串的最小表示法。起先我做的是直接求,不是超時(shí)就是超內(nèi)存。這讓我學(xué)到了很多,有時(shí)候我做題目并不是為AC,而是去學(xué)更多的東西,雖然錯(cuò)了很多次,但是你會(huì)知道是由于什么錯(cuò)了,可以學(xué)更多。
最小表示法------詳細(xì)看博客
#include<bits/stdc++.h> using namespace std;#define e exp(1) #define pi acos(-1) #define mod 1000000007 #define inf 0x3f3f3f3f #define ll long long #define ull unsigned long long #define mem(a,b) memset(a,b,sizeof(a)) int gcd(int a,int b){return b?gcd(b,a%b):a;}int _find(string str) {int i = 0;int j = 1;int k = 0;int len = str.size();while(i<len && j<len && k<len ){int t = str[(i+k)%len] - str[(j+k)%len];if(t == 0)k++;else{if(t>0)i+=(k+1);elsej+=(k+1);if(i == j)j++;k=0;}}return i<j?i:j; } int main() {int T;scanf("%d",&T);while(T--){string s;cin>>s;int cnt=_find(s);printf("%d\n",cnt);}return 0; }?
?
總結(jié)
以上是生活随笔為你收集整理的zcmu1550(字符串最小表示法)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 前后端分离跨域问题解决方案
- 下一篇: 浅谈积性函数求前缀和