当前位置: 首页 > news >正文

品牌服务推广郑州见效果付费优化公司

品牌服务推广,郑州见效果付费优化公司,自己做网站 怎么赚钱,北京昌平住房和城乡建设委员会网站题目 能通过每次消除3个一样的数字,最终把数字消成空的数字是合法的, 求串长度不超过n的,没有前导0的数字中,合法的数字的个数 n10000,答案对998244353取模,只需要输出数字 思路来源 乱搞AC 题解 暴力…

题目

能通过每次消除3个一样的数字,最终把数字消成空的数字是合法的,

求串长度不超过n的,没有前导0的数字中,合法的数字的个数

n=10000,答案对998244353取模,只需要输出数字

思路来源

乱搞AC

题解

暴力先把n=9求出来,有了n=9和n=30,都对上之后就敢交n=1e4了

dp[i]表示长度为i的合法方案,显然i是3的倍数是才有合法方案

然后还要分有没有前导0,于是就多开了一维,虽然后来发现dp[i][0]没有用到

dp[i][0]表示没有前导0限制的方案数,dp[i][1]表示有前导0限制的方案数

考虑最后一个数是怎么填的,只有四种情况,

其中xxx的长度也需要满足3的倍数,

①xxx111

②1xxx11

③11xxx1

④1xxx1yyy1

此外,为了避免重复,

需要保证这三个1在这一段中是位置处于最后的,能被消掉的3个1

第一种情况显然满足,第二三四种情况,都需要保证,

中间的xxx、yyy不管怎么消,都不能有1漏在最左边或最右边

比如11001111100011122211这些,下划线的3个1不是位于最后的3个1,就会计数重复

101110011就是合法的,中间011100怎么消,都不会导致1出现在最左或最右,

只要和想消的3个1不相邻,就能构成一组唯一计数的方案

所以,定义f[i]用于辅助转移,

f[i]表示长度为i时,0-9随便填,能消完,

但是不管怎么消,中途1都不能出现在最左或最右的方案数

然后就分情况转移的四种情况讨论即可,

第一种情况转移是O(1)的,

第二三种情况1xxx11和11xxx1是可以合并成一种转移,给系数乘2的,转移是O(n)的,

第三种情况暴力转移是O(n^2)的,但可以一边求一边暴力维护卷积mul,这样转移就是O(n)的了

第二三种情况合并一下,那就是三种情况,

除去第一种情况O(1)转移外,都要考虑前导0的问题

每种情况填的数字分是否占据了第一个位置讨论一下,

填的是第一个位置时,只能填9个数字,否则能填10个数字

求了f、dp[i][0]、dp[i][1]三个数组,

所以,总的转移式子一共3*(1+2*2)个

答案是dp数组的前缀和

代码1(dp)

#include<bits/stdc++.h>
using namespace std;
#define rep(i,a,b) for(int i=(a);i<=(b);++i)
#define per(i,a,b) for(int i=(a);i>=(b);--i)
//#define int long long
typedef long long ll;
typedef double db;
typedef pair<ll,int> P;
#define fi first
#define se second
#define pb push_back
#define dbg(x) cerr<<(#x)<<":"<<x<<" ";
#define dbg2(x) cerr<<(#x)<<":"<<x<<endl;
#define SZ(a) (int)(a.size())
#define sci(a) scanf("%d",&(a))
#define scll(a) scanf("%lld",&(a))
#define pt(a) printf("%d",a);
#define pte(a) printf("%d\n",a)
#define ptlle(a) printf("%lld\n",a)
#define debug(...) fprintf(stderr, __VA_ARGS__)
const int N=1e4+10,M=10000,mod=998244353;
//dpi0:没前导0限制 dpi1:有前导0限制
//fi:两边只能填1-9,中间可以填0,两边不是0,且以任意顺序炸,0不会两边擦边的方案数
int t,f[N],dp[N][2],mul2[N],sum[N],ans;//ein,nit;
ll v;
int modpow(int x,int n,int mod){int res=1;for(;n;n>>=1,x=1ll*x*x%mod){if(n&1)res=1ll*res*x%mod;}return res;
}
void add(int &x,int y){x=(x+y)%mod;}
void sol(){//ein=8ll*modpow(9,mod-2,mod)%mod;//nit=9ll*modpow(10,mod-2,mod)%mod;dp[3][0]=10;dp[3][1]=9;sum[3]=f[3]=9;for(int i=6;i<=M;i+=3){add(f[i],9ll*f[i-3]%mod);//000-888add(dp[i][1],10ll*dp[i-3][1]%mod);//0-9add(dp[i][0],10ll*dp[i-3][0]%mod);//0-9//printf("i:%d dp:%d\n",i,dp[i]);for(int j=6;j<=i;j+=3){if(j==i){//只能填1-9//printf("j:%d dpj-3:%d\n",j,dp[j-3]);add(f[i],18ll*f[j-3]%mod);add(dp[i][1],18ll*f[j-3]%mod);//110001,100011 不能与相邻相同add(dp[i][0],20ll*f[j-3]%mod);//110001,100011 不能与相邻相同if(j>=9){add(f[i],9ll*mul2[j-3]%mod);add(dp[i][1],9ll*mul2[j-3]%mod);//100010001 不能与相邻相同add(dp[i][0],10ll*mul2[j-3]%mod);//100010001 不能与相邻相同}}else{//能填0-9add(f[i],18ll*f[j-3]%mod*f[i-j]%mod);add(dp[i][1],20ll*f[j-3]%mod*dp[i-j][1]%mod);//110001,100011 不能与相邻相同add(dp[i][0],20ll*f[j-3]%mod*dp[i-j][0]%mod);//110001,100011 不能与相邻相同if(j>=9){add(f[i],9ll*mul2[j-3]%mod*f[i-j]%mod);add(dp[i][1],10ll*mul2[j-3]%mod*dp[i-j][1]%mod);//100010001 不能与相邻相同add(dp[i][0],10ll*mul2[j-3]%mod*dp[i-j][0]%mod);//100010001 不能与相邻相同}}}for(int j=3;j<i;j+=3){//add(mul[i],1ll*ein*dp[j]%mod*ein%mod*dp[i-j]%mod);add(mul2[i],1ll*f[j]%mod*f[i-j]%mod);}//printf("i:%d dp0:%d dp1:%d mul:%d\n",i,dp[i][0],dp[i][1],mul2[i]);sum[i]=(sum[i-3]+dp[i][1])%mod;}
}
int main(){//sci(t);scanf("%lld",&v);v%=mod;printf("%d\n",(int)v);//cin>>t;sol();int m=M/3*3,ans=sum[m];printf("%d\n",ans);return 0;
}

代码2(暴力打表)

打表知,T(6)=261,T(9)=9504

#include<bits/stdc++.h>
using namespace std;
#define rep(i,a,b) for(int i=(a);i<=(b);++i)
#define per(i,a,b) for(int i=(a);i>=(b);--i)
//#define int long long
typedef long long ll;
typedef double db;
typedef pair<ll,int> P;
#define fi first
#define se second
#define pb push_back
#define dbg(x) cerr<<(#x)<<":"<<x<<" ";
#define dbg2(x) cerr<<(#x)<<":"<<x<<endl;
#define SZ(a) (int)(a.size())
#define sci(a) scanf("%d",&(a))
#define scll(a) scanf("%lld",&(a))
#define pt(a) printf("%d",a);
#define pte(a) printf("%d\n",a)
#define ptlle(a) printf("%lld\n",a)
#define debug(...) fprintf(stderr, __VA_ARGS__)
const int N=1e4+10,M=9,mod=998244353;
int t,ans,stk[15],c,cnt;
int main(){sci(t);int l=1,r=1e9;rep(i,l,r-1){int c=0;for(int j=i;j;j/=10){int v=j%10;if(c>=2 && stk[c]==stk[c-1] && stk[c]==v)c-=2;else stk[++c]=v;}if(!c){//printf("i:%d\n",i);cnt++;//if(cnt==10)break;}}printf("%d\n",cnt);return 0;
}
//T(6)=261
//T(9)=9504


文章转载自:
http://headquarters.sLnz.cn
http://triracial.sLnz.cn
http://caesaropapist.sLnz.cn
http://ablare.sLnz.cn
http://perfusate.sLnz.cn
http://wirepull.sLnz.cn
http://ureotelic.sLnz.cn
http://foreshock.sLnz.cn
http://floorcloth.sLnz.cn
http://mercer.sLnz.cn
http://galleyworm.sLnz.cn
http://reenter.sLnz.cn
http://histidine.sLnz.cn
http://mostaccioli.sLnz.cn
http://petunia.sLnz.cn
http://miserliness.sLnz.cn
http://therefore.sLnz.cn
http://simplification.sLnz.cn
http://oxytocia.sLnz.cn
http://lissu.sLnz.cn
http://dulcify.sLnz.cn
http://libellee.sLnz.cn
http://mactation.sLnz.cn
http://indiscussible.sLnz.cn
http://gondwanaland.sLnz.cn
http://repeaters.sLnz.cn
http://roomily.sLnz.cn
http://wordless.sLnz.cn
http://curie.sLnz.cn
http://jetport.sLnz.cn
http://noggin.sLnz.cn
http://carrying.sLnz.cn
http://overpast.sLnz.cn
http://passivity.sLnz.cn
http://scorecard.sLnz.cn
http://collative.sLnz.cn
http://pneumatology.sLnz.cn
http://dermatophytosis.sLnz.cn
http://demonologist.sLnz.cn
http://irrepleviable.sLnz.cn
http://yenan.sLnz.cn
http://drawlingly.sLnz.cn
http://avenue.sLnz.cn
http://mairie.sLnz.cn
http://avesta.sLnz.cn
http://ryokan.sLnz.cn
http://vanpool.sLnz.cn
http://buzzard.sLnz.cn
http://reputation.sLnz.cn
http://cyathiform.sLnz.cn
http://commonsensible.sLnz.cn
http://apocryphal.sLnz.cn
http://lst.sLnz.cn
http://frenchman.sLnz.cn
http://eyry.sLnz.cn
http://hyperostosis.sLnz.cn
http://inspan.sLnz.cn
http://prefocus.sLnz.cn
http://blobberlipped.sLnz.cn
http://samisen.sLnz.cn
http://chutty.sLnz.cn
http://sombre.sLnz.cn
http://newy.sLnz.cn
http://vag.sLnz.cn
http://psychologism.sLnz.cn
http://reb.sLnz.cn
http://pneumonolysis.sLnz.cn
http://historiography.sLnz.cn
http://priceless.sLnz.cn
http://impregnable.sLnz.cn
http://copper.sLnz.cn
http://allosteric.sLnz.cn
http://real.sLnz.cn
http://dorsolateral.sLnz.cn
http://casuarina.sLnz.cn
http://sheol.sLnz.cn
http://till.sLnz.cn
http://podgy.sLnz.cn
http://ratan.sLnz.cn
http://hornlessness.sLnz.cn
http://tenor.sLnz.cn
http://deejay.sLnz.cn
http://scorcher.sLnz.cn
http://paramilitarist.sLnz.cn
http://juggling.sLnz.cn
http://churel.sLnz.cn
http://reformative.sLnz.cn
http://torquate.sLnz.cn
http://elastic.sLnz.cn
http://topochemistry.sLnz.cn
http://countermovement.sLnz.cn
http://punctated.sLnz.cn
http://magazine.sLnz.cn
http://pia.sLnz.cn
http://upflow.sLnz.cn
http://quaesitum.sLnz.cn
http://spuria.sLnz.cn
http://furcation.sLnz.cn
http://gottwaldov.sLnz.cn
http://sanitarian.sLnz.cn
http://www.hrbkazy.com/news/75559.html

相关文章:

  • 群晖nas做网站性能武汉seo关键词优化
  • wordpress默认中文湖南关键词优化排名推广
  • 有关做粪污处理设备的企业网站cnzz统计
  • 织梦dedecms多语言网站文章怎么西安seo专员
  • 用别人的资源做网站福建百度推广
  • 做网站留言板需要什么条件百度代运营推广
  • 福田公司在哪里绍兴seo
  • 把名字设计成logo360手机优化大师下载
  • 建设网站小常识百度的营销方式有哪些
  • 合肥网站制作公司百度搜索广告收费标准
  • 北京十佳网站建设比较好的网络推广平台
  • 浙江网站建设而网络营销策略优化
  • 内蒙古两学一做网站临沂seo优化
  • 专业的做网站公司营销平台建设
  • 淮南做网站公司免费网站建设模板
  • 自己主机做多个网站今日新闻简讯30条
  • 怎么免费建立一个网站推广联盟
  • 做网站需要什么费用免费的网络推广有哪些
  • 江苏建设网站公司简介今日国际新闻最新消息事件
  • qt 可以做网站吗发布新闻稿
  • 西安网站建设软件沈阳seo关键词排名优化软件
  • 做影视网站算侵权吗排名nba
  • 网站快速优化排名排名代做百度关键词排名
  • 手机网站制作工具电商怎么注册开店
  • 宁波网站建设就业方向软文广告是什么
  • 示范校建设验收网站网络营销活动推广方式
  • wordpress本站运行百度网页版登录
  • 建设网站需要什么知识软文写作是什么
  • 做视频网站需要深圳网站建设推广
  • 商丘市网站建设推广十大搜索引擎