POJ 2018 Best Cow Fences (二分答案构造新权值 or 斜率优化)
                                                            生活随笔
收集整理的這篇文章主要介紹了
                                POJ 2018 Best Cow Fences (二分答案构造新权值 or 斜率优化)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.                        
                                $ POJ~2018~Best~Cow~ Fences $(二分答案構造新權值)
$ solution: $
題目大意:
給定正整數數列 $ A $ ,求一個平均數最大的長度不小于 $ L $ 的子段
$ code: $
#include<iostream> #include<cstdio> #include<iomanip> #include<algorithm> #include<cstring> #include<cstdlib> #include<ctime> #include<cmath> #include<vector> #include<queue> #include<map> #include<set>#define ll long long #define db double #define rg register intusing namespace std;const int mod=9901;int n,m,ans;inline int qr(){register char ch; register bool sign=0; rg res=0;while(!isdigit(ch=getchar()))if(ch=='-')sign=1;while(isdigit(ch))res=res*10+(ch^48),ch=getchar();if(sign)return -res; else return res; }inline int ksm(ll x,int y){ll res=1;while(y){if(y&1)res=res*x%mod;x=x*x%mod; y>>=1;}return res; }inline int ask(int x,int y){if(y==1)return x;if(y&1) return ((ll)ask(x,y>>1)*(ksm(x,y>>1)+1)%mod+ksm(x,y)%mod)%mod;else return (ll)ask(x,y>>1)*(ksm(x,y>>1)+1)%mod; }int main(){//freopen(".in","r",stdin);//freopen(".out","w",stdout);while(~scanf("%d%d",&n,&m)){if(m==0){puts("1");continue;}ans=1;for(rg i=2;i*i<=n;++i){if(n%i)continue;rg x=0; while(!(n%i))++x,n/=i;ans=(ll)ans*(ask(i%mod,x*m)+1)%mod;}if(n!=1)ans=(ll)ans*(ask(n%mod,m)+1)%mod;printf("%d\n",ans);}return 0; }轉載于:https://www.cnblogs.com/812-xiao-wen/p/11248810.html
總結
以上是生活随笔為你收集整理的POJ 2018 Best Cow Fences (二分答案构造新权值 or 斜率优化)的全部內容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: 图片滑动效果(转)
 - 下一篇: POJ 3889 Fractal Str