Codeforces 1321A - Contest for Robots AcWing 3767. 最小的值 每日一题7.14(贪心)

题目

        Problem - 1321A - Codeforces

        3767. 最小的值 - AcWing题库

给定两个长度为 n 的 01 数组 a_1,a_2,...,a_n 和 b_1,b_2,...,b_n

请你构造一个长度为 n 的正整数数组 p_1,p_2,...,p_n

要求 \sum_{i=1}^{n}a_i \times p_i > \sum_{i=1}^{n}b_i \times p_i 成立。

此外,\max_{i=1}^{n}p_i 需要尽可能小。

输出最小可能值。

思路

        对于每一位对位一共有四种情况,分别是<0,0>,<1,0>,<0,1>,<1,1>两两组合,其中<0,0>和<1,1>是没有意义的,因为他们对于任何一个p_i对于求和都是相等的,所以我们考虑01,与10。

        统计01和10个数,分别为cnt1和cnt2,有下面几种情况:

        1)cnt1=0  这个时候无论如何不等式都不会满足,输出-1

        2)cnt1<cnt2(cnt1>0) 这个时候为了使其最小,那么对于任何的01组合pi都为1,那么就要想尽办法让10追上01,这时候平均分下去,还得+1,毕竟不能相等

        3)cnt1=cnt2  这个时候只需要给其中一个10组合pi=2即可

        4)cnt1>cnt2   那么pi全部为1即可

代码

#include<stack>
#include<cstdlib>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<queue>
#include<cstring>
#include<deque>
#include<vector>
#include<iostream>
#include<map>
#include<set>
#include<iomanip>
#define IOS ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
#define ll long long
using namespace std;
ll GCD(ll a,ll b){while(b^=a^=b^=a%=b);return a;}
const int inf=0x3f3f3f3f;
int a[110],b[110],cnt1,cnt2,n;
signed main() 
{
    #ifndef ONLINE_JUDGE
		    freopen("IO\\in.txt","r",stdin);
		    freopen("IO\\out.txt","w",stdout);
        #endif
    IOS
    cin>>n;
    for (int i=1;i<=n;i++) cin>>a[i];
    for (int i=1;i<=n;i++) cin>>b[i];
    for (int i=1;i<=n;i++)
    {
        if (a[i]==1&&b[i]==0) cnt1++;
        if (a[i]==0&&b[i]==1) cnt2++;
    }
    if (cnt1==0) cout<<-1;
    else if (cnt1==cnt2) cout<<2;
    else if (cnt1>cnt2) cout<<1;
    else cout<<cnt2/cnt1+1;
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值