设为首页 加入收藏

TOP

CodeForces 7D Palindrome Degree 字符串hash
2015-07-24 05:52:06 来源: 作者: 【 】 浏览:4
Tags:CodeForces Palindrome Degree 字符串 hash

题目链接:点击打开链接





#include
  
   
#include
   
     #include
    
      #include
     
       #include
      
        #include
        #include
        
          #include
         
           #include
          
            #include
           
             #include
            
              using namespace std; #define N 5001000 #define mod 1000000007 #define hehe 137731735 #define ll __int64 ll n; char s[N]; ll x[N], y[N]; ll dp[N]; int main(){ ll i,j; while(gets(s)) { dp[0] = 0; for(i=0;s[i];i++) { if('0'<=s[i]&&s[i]<='9') s[i] = s[i]-'0'; else if('a'<=s[i]&&s[i]<='z') s[i] = s[i]-'a'+10; else s[i] = s[i]-'A'+36; } ll len = i; x[0] = 0; ll dou = 1; for(i=1;i<=len;i++){ x[i] = (x[i-1]+s[i-1]*dou)%mod; dou = (dou*hehe)%mod; } y[len+1] = 0; for(i=1;i<=len;i++) { y[i] = (y[i-1]*hehe+s[i-1])%mod;} ll ans = 0; for(i=1;i<=len;i++) if(x[i]==y[i]) { dp[i] = dp[i>>1]+1; ans += dp[i]; } cout<
             
              

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇一、从Java、C#到C++ (为什么C++.. 下一篇VC++ 创建msi文件

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: