AIM Tech Round 3 (Div. 2) D. Recover the String (构造)

题目点我点我点我


D. Recover the String
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

For each string s consisting of characters '0' and '1' one can define four integers a00a01a10 and a11, where axy is the number ofsubsequences of length 2 of the string s equal to the sequence {x, y}.

In these problem you are given four integers a00a01a10a11 and have to find any non-empty string s that matches them, or determine that there is no such string. One can prove that if at least one answer exists, there exists an answer of length no more than1 000 000.

Input

The only line of the input contains four non-negative integers a00a01a10 and a11. Each of them doesn't exceed 109.

Output

If there exists a non-empty string that matches four integers from the input, print it in the only line of the output. Otherwise, print "Impossible". The length of your answer must not exceed 1 000 000.

Examples
input
1 2 3 4
output
Impossible
input
1 2 2 1
output
0110




/* ***********************************************
┆  ┏┓   ┏┓ ┆
┆┏┛┻━━━┛┻┓ ┆
┆┃       ┃ ┆
┆┃   ━   ┃ ┆
┆┃ ┳┛ ┗┳ ┃ ┆
┆┃       ┃ ┆
┆┃   ┻   ┃ ┆
┆┗━┓ 马 ┏━┛ ┆
┆  ┃ 勒 ┃  ┆      
┆  ┃ 戈 ┗━━━┓ ┆
┆  ┃ 壁     ┣┓┆
┆  ┃ 的草泥马  ┏┛┆
┆  ┗┓┓┏━┳┓┏┛ ┆
┆   ┃┫┫ ┃┫┫ ┆
┆   ┗┻┛ ┗┻┛ ┆
************************************************ */

#include <stdio.h>
#include <string.h>
#include <iostream>
#include <algorithm>
#include <vector>
#include <queue>
#include <stack>
#include <set>
#include <map>
#include <string>
#include <math.h>
#include <stdlib.h>
#include <bitset>
using namespace std;

#define rep(i,a,b) for (int i=(a),_ed=(b);i<=_ed;i++)
#define per(i,a,b) for (int i=(b),_ed=(a);i>=_ed;i--)
#define pb push_back
#define mp make_pair
const int inf_int = 2e9;
const long long inf_ll = 2e18;
#define inf_add 0x3f3f3f3f
#define mod 1000000007
#define LL long long
#define ULL unsigned long long
#define MS0(X) memset((X), 0, sizeof((X)))
#define SelfType int
SelfType Gcd(SelfType p,SelfType q){return q==0?p:Gcd(q,p%q);}
SelfType Pow(SelfType p,SelfType q){SelfType ans=1;while(q){if(q&1)ans=ans*p;p=p*p;q>>=1;}return ans;}
#define Sd(X) int (X); scanf("%d", &X)
#define Sdd(X, Y) int X, Y; scanf("%d%d", &X, &Y)
#define Sddd(X, Y, Z) int X, Y, Z; scanf("%d%d%d", &X, &Y, &Z)
#define reunique(v) v.resize(std::unique(v.begin(), v.end()) - v.begin())
#define all(a) a.begin(), a.end()
typedef pair<int, int> pii;
typedef pair<long long, long long> pll;
typedef vector<int> vi;
typedef vector<long long> vll;
inline int read(){int ra,fh;char rx;rx=getchar(),ra=0,fh=1;while((rx<'0'||rx>'9')&&rx!='-')rx=getchar();if(rx=='-')fh=-1,rx=getchar();while(rx>='0'&&rx<='9')ra*=10,ra+=rx-48,rx=getchar();return ra*fh;}
//#pragma comment(linker, "/STACK:102400000,102400000")


int f(int x)
{
    if(x&1)return (x-1)/2*x;
    else return x/2*(x-1);
}


int main()
{
	//freopen("in.txt","r",stdin);
	//freopen("out.txt","w",stdout);
	ios::sync_with_stdio(0);
	cin.tie(0);
	int a,b,c,d;
	scanf("%d%d%d%d",&a,&b,&c,&d);
	int flag = 0;
	int A=0,B=0;
	for(int i=0;f(i)<=a;i++)
    {
        if(f(i)==a)
        {
            for(int j=0;f(j)<=d;j++)
            {
                if(f(j)==d)
                {
                    if(i*j==b+c)
                    {
                        A = i;
                        B = j;
                        flag = 1;
                    }
                }
            }
        }
    }
    if(!flag)
    {
        printf("Impossible\n");
    }
    else
    {
        int sum = A + B;
        for(int i=1;i<=sum;i++)
        {
            if(c>=A)
            {
                c -= A;
                B--;
                printf("1");
            }
            else
            {
                A--;
                printf("0");
            }
        }
        printf("\n");
    }


	return 0;
}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DB历史主题丢失是指数据库历史记录的主题内容不见了。这种情况下,我们可以尝试通过重新配置来恢复它。 首先,我们需要检查数据库配置文件,确保历史记录功能没有被禁用或配置错误。检查配置文件中与历史记录相关的参数设置,如历史记录的保留时间、历史记录文件的存储位置等。如果这些参数设置正确,但历史主题仍然丢失,我们可以尝试以下步骤进行恢复。 1. 停止数据库服务:首先,需要停止正在运行的数据库服务,以便执行下一步的操作。 2. 备份数据库:在进行任何恢复操作之前,务必先备份数据库文件,以防止意外数据丢失。 3. 清空历史记录相关文件:进入数据库目录,并删除与历史记录相关的文件,如历史记录日志文件、历史记录索引文件等。这样做的目的是清除之前可能存在的损坏的历史记录文件。 4. 重新配置数据库:编辑数据库配置文件,重新启用历史记录功能并确保相应的参数设置正确。 5. 启动数据库服务:保存更改后,重新启动数据库服务,让新的配置生效。 6. 监视恢复进程:在数据库启动后,我们可以通过监视日志或使用数据库管理工具,验证历史记录是否被正确恢复。可以查看历史记录是否开始重新生成,以及检查历史记录文件是否存在以及大小是否与预期一致。 7. 测试恢复结果:使用数据库客户端连接到数据库,并执行一些操作,以验证历史记录是否正常工作。可以查询历史记录文件,查看相应的操作是否已被记录。 总之,当DB历史主题丢失时,我们可以尝试通过重新配置数据库来恢复它。这个过程需要注意备份数据、重要文件的清除和重新配置以及验证恢复结果等步骤,以确保恢复过程顺利且有效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值