zoukankan      html  css  js  c++  java
  • CF1138D.Camp Schedule

    传送门

    虽然是D,但是还是Sb题,把模式串跑一遍KMP,然后把按顺序放,每次放完之后跳到对应的前缀,继续放。
    如果最后1的数量还有剩,再将最后的位数全部放1
    代码:

    #include<cstdio>
    #include<iostream>
    #include<algorithm>
    #include<cstring>
    using namespace std;
    void read(int &x) {
    	char ch; bool ok;
    	for(ok=0,ch=getchar(); !isdigit(ch); ch=getchar()) if(ch=='-') ok=1;
    	for(x=0; isdigit(ch); x=x*10+ch-'0',ch=getchar()); if(ok) x=-x;
    }
    #define rg register
    const int maxn=5e5+10;
    char p[maxn],s[maxn];
    int num,num1,len,len1,nxt[maxn],ans;
    int main()
    {
    	scanf("%s",p+1),scanf("%s",s+1);
    	len=strlen(p+1),len1=strlen(s+1);
    	for(rg int i=1;i<=len;i++)if(p[i]=='1')num++;
    	for(rg int i=1;i<=len1;i++)if(s[i]=='1')num1++;
    	if(num<num1||len<len1)
    	{
    		for(rg int i=1;i<=len;i++)printf("%c",p[i]);
    		printf("
    ");return 0;
    	}
    	for(rg int i=2,j=0;i<=len1;i++)
    	{
    		while(j&&s[j+1]!=s[i])j=nxt[j];
    		if(s[j+1]==s[i])j++;
    		nxt[i]=j;
    	}
    	ans=len+1;
    	for(rg int i=1,j=0;i<=len;i++)
    	{
    		if(num&&s[j+1]=='1')num--,p[i]='1',j++;
    		else if(s[j+1]=='0')j++,p[i]='0';
    		else {ans=i;break;}
    		if(j==len1)j=nxt[j];
    	}
    	for(rg int i=ans;i<=len;i++)p[i]='0';
    	while(num)
    	{
    		ans--;
    		if(p[ans]=='1')num++;
    		num--,p[ans]='1';
    	}
    	for(rg int i=1;i<=len;i++)printf("%c",p[i]);
    }
    
  • 相关阅读:
    教你当主管:如何降低你的员工流失率?
    你问我这算什么
    推荐:职场提升的10条捷径
    压力从何而来呢?千万不要2008年结婚
    怎样“管理”你的上司?
    HTTP.sys
    IIS书籍
    IIS目录
    HTTP服务
    在 IIS 7 中使用配置文件
  • 原文地址:https://www.cnblogs.com/lcxer/p/10499893.html
Copyright © 2011-2022 走看看