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

厦门网站建设qs-net.cn有哪些推广平台和渠道

厦门网站建设qs-net.cn,有哪些推广平台和渠道,定制柜,新网备案成功了怎么做网站链接:Iroha Loves Strings - AtCoder arc058_d - Virtual Judge 利用bitset这一数据结构,定义bitset类型的变量dp[i]表示第i到n个字符串能拼成的字符串长度都有哪些,比如00100101,表示能拼成的长度有0,2,5,&#xff0…

链接:Iroha Loves Strings - AtCoder arc058_d - Virtual Judge

利用bitset这一数据结构,定义bitset类型的变量dp[i]表示第i到n个字符串能拼成的字符串长度都有哪些,比如00100101,表示能拼成的长度有0,2,5,(注意:bitset中的元素从右往左看,下标从0开始),利用递推关系更新dp[i]如下
dp[i] = dp[i+1] | (dp[i+1] << s[i]的长度)
若dp[i][k] = 1,说明第i到第n个字符串可以拼成长度为k的字符串


之后模拟取数,i从1到k进行遍历,每次取当前能取的最小的字符,具体实现方式如下:(以下描述建议结合代码看)


定义候选对数组 pair<int,int> sel[i][j],i为0或1(用作开关变量),j是候选对象的编号,从1到cnt或ncnt,每个sel[i][j]中存的是
<候选字符所在的字符串的序号,候选字符在该字符串中的下标>
第一个字符的候选字符串i,要满足dp[i+1][k-s[i]的长度] = 1,也就是选了第i个字符串后,之后的字符串必须保证能拼成(k-s[i]的长度)的长度的字符串,将pair<i,0>加入sel


i从1到k遍历,每次在所有候选字符中选择字典序最小的那个字符作为答案,接着分情况讨论:
1.如果字符串还没用完,就继续将该字符串的下一个元素加入候选队列,如果有这样的字符串:
ab和ac,那么b和c都应该加入候选队列,

2.如果有一个字符串用完了,可能出现这样的情况:abc abc,这时应该先选前面的“abc”,因为选完编号为i的字符串后,新入选的字符串的下标从 i+1 开始,如果选了第二个或后面的,就会有字符串没法被用到,从而导致丢失解或错误解,新入选的字符串(编号为 j )要满足dp[ j+1 ][ k-i-新字符串的长度 ]等于1,这样选其能确保最终构成的字符串有可能长度为k,将pair<新字符串的编号,0>加入sel中

复杂度估计:nk

注意:

bitset和pair定义的先后会影响程序运行对错,正确的顺序是先定义bitset后定义pair,原因涉及到C++语言本身

#include<bits/stdc++.h>
using namespace std;const int maxn=2005,maxk=1e4+5;
char s[maxn][maxk];
int len[maxn];
int n,k;
bitset<maxk> dp[maxn];
pair<int,int> sel[2][maxn];//pair和bitset的先后问题int main()
{ios::sync_with_stdio(0);cin.tie(0);//freopen("D:\\in.txt","r",stdin);cin>>n>>k;for(int i=1;i<=n;i++){cin>>s[i];len[i]=strlen(s[i]);}dp[n+1][0]=1;for(int i=n;i>=1;i--){dp[i]=(dp[i+1] | (dp[i+1]<<len[i]));}int cnt=0;//挑出第一个字符的可选对象for(int i=1;i<=n;i++){if(dp[i+1][k-len[i]]){//printf("%d可选\n",i);sel[0][++cnt]={i,0};}}int t=1;for(int i=1;i<=k;i++){int ncnt=0;t^=1;char cur='z';for(int j=1;j<=cnt;j++){cur=min(cur,s[sel[t][j].first][sel[t][j].second]);}cout<<cur;//更新下一组候选对象int minid=n+1;for(int j=1;j<=cnt;j++){int id=sel[t][j].first,pos=sel[t][j].second;if(s[id][pos]!=cur) continue;if(pos<len[id]-1){sel[t^1][++ncnt]={id,pos+1};}else{minid=min(minid,id);       //选序号最小的,这样后面的字符串还能用得上(不然会白白浪费字符串)}}for(int j=minid+1;j<=n;j++){if(k-i-len[j]>=0 && dp[j+1][k-i-len[j]]){sel[t^1][++ncnt]={j,0};}}cnt=ncnt;}return 0;
}

http://www.mmbaike.com/news/77398.html

相关文章:

  • 民政局网站建设方案如何弄一个自己的网站
  • 音乐网站设计规划书申请域名的方法和流程
  • asp网站建设技术方案网络软文营销案例
  • 商城网站怎样做域名交易域名出售
  • 有项目怎么找投资人seo综合查询是什么意思
  • 南京建设局的网站首页seo怎么做优化
  • 网站建设西安项目推广方式有哪些
  • 无锡做网站优化公司公司页面设计
  • 网加商学院网站怎么做培训机构网站模板
  • 嘉兴 网站 制作广告公司推广方案
  • 上海高端网站建设seo搜索是什么
  • 网站用户告知书北京搜索引擎优化
  • 电销卡代理加盟池州网站seo
  • 怎么做淘客推广网站谷歌排名
  • 怎么做各大视频网站的会员代理谷歌推广效果怎么样
  • 廊坊那家做网站排行榜seo排名计费系统
  • 手机网站建设制作长沙seo技术培训
  • 电商购物网站开发需求分析网络运营主要做什么工作
  • 免费做毕业视频的网站广州网络营销的推广
  • 设计素材网站解析网络营销机构官方网站
  • 移动微网站建设二维码花都网络推广seo公司
  • ftp上传文件到网站南昌百度网站快速排名
  • 北京市网站建设公司排名河北网站优化公司
  • 做两个阿里网站吗百度主页网址
  • 建设局网站模板国内免费二级域名建站
  • dede网站头部不显示调用的名称顶尖文案网站
  • h5建设网站公司关键词大全
  • 科技九洲君北京优化seo
  • 做我女朋友网站电商平台怎么注册
  • 做英文网站org域名注册