(更新中)【2020.7.10】“华为杯”中国矿业大学程序设计学科竞赛重现赛补题

B.
(更新中)【2020.7.10】“华为杯”中国矿业大学程序设计学科竞赛重现赛补题_第1张图片
题意:
a表示城市i能否传送到更大的城市
b表示城市i能否传送到更小的城市
问:从1开始能否到m

#include 
using namespace std;
typedef long long ll;
const int maxn = 1e6 + 100;
const int mod = 1e9 + 7;
int a[maxn], b[maxn];

int main() {
    int n, m;
    while (cin >> n >> m) {
        for (int i = 1; i <= n; i++) cin >> a[i];
        for (int i = 1; i <= n; i++) cin >> b[i];

        int ans = 0;
        if (a[1] == 0) ans = 0;
        else if (a[m]) ans = 1;
        else if (!b[m]) ans = 0;
        else {
            bool flag = false;

            for (int i = m + 1; i <= n; i++) {
                if (a[i] & b[i]) {
                    flag = true;
                    ans = 1;
                    break;
                }
            }

            if (!flag) ans = 0;
        }

        if (ans) cout << "YES\n";
        else cout << "NO\n";
        }

    return 0;
}

C

(更新中)【2020.7.10】“华为杯”中国矿业大学程序设计学科竞赛重现赛补题_第2张图片

题意:把一个数组的每一个数都变成它们和的均值,每一次操作可以把一个a[i]的部分值移动到相邻的数上,问最少操作次数。
思路:对于不等于平均值的,贪心地从右边补(因为不区别是>m还是

#include 
using namespace std;
typedef long long ll;
const int maxn = 1e6 + 100;
const int mod = 1e9 + 7;
int a[maxn];

int main() {
    int n;

    while (cin >> n) {
        int m = 0, ans = 0;

        for (int i = 1; i <= n; i++) cin >> a[i], m += a[i];

        m /= n;

        for (int i = 1; i <= n; i++) {
            if (a[i] != m) {
                a[i + 1] += a[i] - m;
                ans++;
            }
        }

        cout << ans << endl;
    }
    
    return 0;
}

你可能感兴趣的:(ACM,acm)