2019牛客暑期多校训练营(第六场)

题号 标题 已通过代码 题解/讨论 通过率 团队的状态
A Garbage Classification 点击查看 进入讨论 1036/1650 img
B Shorten IPv6 Address 点击查看 进入讨论 804/5504 img
C Palindrome Mouse 点击查看 进入讨论 175/467 img
D Move 点击查看 进入讨论 943/5467 img
E Androgynos 点击查看 进入讨论 263/1029 补题通过
F K-ary Heap 点击查看 进入讨论 33/100 未通过
G Is Today Friday? 点击查看 进入讨论 465/2276 补题通过
H Train Driver 点击查看 进入讨论 74/284 未通过
I Can They Go to Galar? 点击查看 进入讨论 29/134 未通过
J Upgrading Technology 点击查看 进入讨论 926/5235 img

ps:这场只做了C题,第一次场上做出来这种题,虽然花时间久了点。其他都队友做的orz

A

#include <bits/stdc++.h>
using namespace std;
int T;
char a[10005];
char b[30];
int kase = 0;
int main(){
    scanf("%d", &T);
    while(T--){
        scanf("%s%s", a, b);
        int h, d, w;
        d = w = h = 0;
        int n = 0;
        for(int i = 0; a[i]; i++){
            if(b[a[i] - 'a'] == 'h'){
                h++;
            }
            else if(b[a[i] - 'a'] == 'w'){
                w++;
            }
            else if(b[a[i] - 'a'] == 'd'){
                d++;
            }
            n++;
        }
        kase++;
        printf("Case #%d: ", kase);
        double p = double(h) / double(n);
        if(p >= 0.25){
            printf("Harmful\n");
        }
        else if(p <= 0.1){
            printf("Recyclable\n");
        }
        else if(d >= 2 * w){
            printf("Dry\n");
        }
        else{
            printf("Wet\n");
        }
    }
    return 0;
}

B

#include <bits/stdc++.h>
 
using namespace std;
 
int T;
 
char a[10005];
 
int kase = 0;
 
int b[50];
 
string c[10];
 
vector<string> ans;
 
int min_l;
 
char change(int a){
    if(a < 10){
        return a + '0';
    }
    else{
        return a - 10 + 'a';
    }
}
 
bool allzero(int l, int r){
    if(l > 0 && c[l - 1] == string("0")){
        return false;
    }
    if(r < 7 && c[r + 1] == string("0")){
        return false;
    }
    for(int i = l; i <= r; i++){
        if(c[i] != string("0")){
            return false;
        }
    }
    return true;
}
 
string solve_pre(){
    string p = string("");
    for(int i = 0; i < 8; i++){
        if(i != 0) p += ':';
        p += c[i];
    }
    min_l = min(min_l, int(p.length()));
    return p;
}
void solve(int l, int r){
    string p = string("");
    for(int i = 0; i < l; i++){
        if(i != 0) p += ':';
        p += c[i];
    }
    p += "::";
    for(int i = r + 1; i < 8; i++){
        if(i != r + 1) p += ':';
        p += c[i];
    }
    min_l = min(min_l, int(p.length()));
    ans.push_back(p);
}
int main(){
    scanf("%d", &T);
    while(T--){
        min_l = 10000;
        // 输入和初始化
        scanf("%s", a);
        memset(b, 0, sizeof(b));
        for(int i = 0; i < 10; i++){
            c[i] = string("");
        }
        ans.clear();
        // 四位转换成一个十六进制数
        int t = 0;
        int cnt = 0;
        for(int i = 0; i < 128; i++){
            if((i) && (i % 4 == 0)){
                b[cnt] = t;
                cnt++;
                t = 0;
            }
            t *= 2;
            t |= (a[i] - '0');
        }
        b[cnt] = t;
        // 四位十六进制合成一个字符串
        cnt = 0;
        string ts = string("");
        for(int i = 0; i < 32; i++){
            if(i && (i % 4 == 0)){
                if(ts == string("")){
                    ts = string("0");
                }
                c[cnt] = ts;
                cnt++;
                ts = string("");
            }
            if(ts == string("") && b[i] == 0){
                continue;
            }
            else{
                ts = ts + change(b[i]);
            }
        }
        if(ts == string("")){
            ts = string("0");
        }
        c[cnt] = ts;
        cnt = 0;
        ans.push_back(solve_pre());
        for(int i = 0; i < 8; i++){
            for(int j = i + 1; j < 8; j++){
                if(allzero(i, j)){
                    // cout << "lalala" << endl;
                    solve(i, j);
                }
            }
        }
        kase++;
        printf("Case #%d: ", kase);
        sort(ans.begin(), ans.end());
        for(int i = 0; i < ans.size(); i++){
            if(ans[i].length() == min_l){
                cout << ans[i] << endl;
                break;
            }
        }
        /*
        for(int i = 0; i < ans.size(); i++){
            cout << ans[i] << endl;
        }
        */
    }
    return 0;
}

C

写了篇题解:https://www.cnblogs.com/1625--H/p/11296121.html

D

#include <bits/stdc++.h>
using namespace std;
int n, k;
int a[1005];
  
bool check(int v) {
    bool vis[1005];
    memset(vis, 0, sizeof(bool) * (n + 2));
    int cn = 0;
    int cnt = 0;
    while(1) {
        int las = v;
        if(cn > k) break;
  
        for(int i = n; i >= 1; i--) {
            if(vis[i]) continue;
            if(a[i] <= las) {
                vis[i] = 1;
                las -= a[i];
                cnt++;
                if(cnt == n) break;
            }
        }
        cn++;
        if(cnt == n) break;
    }
    if(cnt < n || cn > k) return false;
    return true;
}
  
int main() {
    int T;
    scanf("%d", &T);
    int cas = 0;
    while(T--) {
        cas++;
        scanf("%d%d", &n, &k);
        int l = 1, r = 0;
        for(int i = 1; i <= n; i++) scanf("%d", &a[i]), r += a[i];
        sort(a + 1, a + 1 + n);
        l = a[n];
  
        int mid = l + r >> 1;
        while(l + 1 < r) {
            mid = l + r >> 1;
  
            if(check(mid)) r = mid;
            else l = mid;
        }
  
        int ans = 0;
        printf("Case #%d: ", cas);
        if(check(l)) ans = l;
        else ans = r;
        for(int i = l; i >= max(a[n], l - 100); i--) {
            if(check(i)) ans = i;
        }
        printf("%d\n", ans);
    }
    return 0;
}

E

#include <bits/stdc++.h>
using namespace std;
 
int tu[2005][2005];
int f[2005];
int main() {
    int T;
    scanf("%d", &T);
    int cas = 0;
    while(T--) {
        int n;
        scanf("%d", &n);
        int tmp = n % 4;
        printf("Case #%d: ", ++cas);
        if(tmp == 2 || tmp == 3) {
            puts("No");
            continue;
        } else puts("Yes");
        for(int i = 1; i <= n; i++)
        for(int j = 1; j <= n; j++) tu[i][j] = 0;
        for(int i = 1; i <= n; i++) f[i] = -1;
 
        int blo = n / 4;
        for(int i = 1; i <= blo * 4; i++) {
            if(i <= blo) {
                for(int j = 1; j <= blo; j++) {
                    if(i == j) continue;
                    tu[i][j] = tu[j][i] = 1;
                }
                for(int j = blo + 1; j <= blo * 2; j++) tu[i][j] = tu[j][i] = 1;
                for(int j = blo * 2 + 1; j <= blo * 3; j++) tu[i][j] = tu[j][i] = 1;
                f[i] = blo * 3 + i;
            } else if(i > blo && i <= blo * 2) {
                for(int j = blo + 1; j <= blo * 2; j++) {
                    if(i == j) continue;
                    tu[i][j] = tu[j][i] = 1;
                }
                for(int j = blo * 3 + 1; j <= blo * 4; j++) tu[i][j] = tu[j][i] = 1;
                f[i] = blo + i;
            } else if(i > blo * 2 && i <= blo * 3) f[i] = i - blo * 2;
            else f[i] = i - blo * 2;
        }
        if(n % 4 == 1) {
            f[n] = n;
            for(int i = blo * 2 + 1; i <= blo * 4; i++) tu[n][i] = tu[i][n] = 1;
        }
        for(int i = 1; i <= n; i++) {
            for(int j = 1; j <= n; j++) printf("%d", tu[i][j]);
            puts("");
        }
        for(int i = 1; i <= n; i++) {
            if(i != n) printf("%d ", f[i]);
            else printf("%d\n", f[i]);
        }
    }
 
    return 0;
}

G

#include <bits/stdc++.h>
using namespace std;
map<int, int> mp;
bool f, ff;
char ss[15];
int s[100005][15];
int n, cnt;
int dp[10005][15][45];
 
bool caile(int y, int m, int d) {
    if(m <= 2) m += 12, y -= 1;
    int c = y / 100;
    y = y - c * 100;
    int w = y + y / 4 + c / 4 - 2 * c + 26 * (m + 1) / 10 + d - 1;
    w %= 7;
    w = (w + 7) % 7;
    if(w == 5) return true;
    return false;
}
 
int l[15], r[15];
int vis[15], to[15];
void dfs(int pos) {
    if(pos > 9) {
        for(int i = 1; i <= cnt; i++) {
            int y = 0, m = 0, d = 0;
            for(int j = 1; j <= 4; j++) y = y * 10 + to[s[i][j]];
            for(int j = 5; j <= 6; j++) m = m * 10 + to[s[i][j]];
            for(int j = 7; j <= 8; j++) d = d * 10 + to[s[i][j]];
            if(y < 1600 || y > 9999 || m > 12 || d > 35) return;
            if(dp[y][m][d] != 5) return;
        }
        ff = true;
        return;
    }
 
    for(int i = l[pos]; i <= r[pos]; i++) {
        if(vis[i] == -1) {
            vis[i] = pos, to[pos] = i;
            dfs(pos + 1);
            if(ff) return;
            vis[i] = -1, to[pos] = -1;
        }
    }
}
 
int mm[] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
int main() {
    memset(dp, -1, sizeof(dp));
    int now = 0;
    for(int i = 1600; i <= 9999; i++) {
        for(int j = 1; j <= 12; j++) {
            int dd = mm[j];
            if(j == 2)
            if(i % 400 == 0 || ((i % 100 != 0) && (i % 4 == 0))) dd++;
            for(int k = 1; k <= dd; k++) {
                dp[i][j][k] = now;
                now++; now %= 7;
            }
        }
    }
    for(int i = 1600; i <= 9999; i++) {
        for(int j = 1; j <= 12; j++) {
            for(int k = 1; k <=35; k++) {
                if(dp[i][j][k] != -1) {
                    dp[i][j][k] = (dp[i][j][k] - 1 + 7) % 7;
                }
            }
        }
    }
 
    int T;
    scanf("%d", &T);
    int cas = 0;
    while(T--) {
        cnt = 0;
        ff = false;
        f = false;
        mp.clear();
        memset(vis, -1, sizeof(vis));
 
        scanf("%d", &n);
        for(int i = 0; i <= 9; i++) l[i] = 0, r[i] = 9;
        for(int i = 1; i <= n; i++) {
            scanf("%s", ss + 1);
            int now = 0;
            now = now * 10 + (ss[1] - 'A');
            now = now * 10 + (ss[2] - 'A');
            now = now * 10 + (ss[3] - 'A');
            now = now * 10 + (ss[4] - 'A');
            now = now * 10 + (ss[6] - 'A');
            now = now * 10 + (ss[7] - 'A');
            now = now * 10 + (ss[9] - 'A');
            now = now * 10 + (ss[10] - 'A');
            if(mp[now]) continue;
            mp[now] = 1;
            s[++cnt][1] = ss[1] - 'A';
            s[cnt][2] = ss[2] - 'A';
            s[cnt][3] = ss[3] - 'A';
            s[cnt][4] = ss[4] - 'A';
            s[cnt][5] = ss[6] - 'A';
            s[cnt][6] = ss[7] - 'A';
            s[cnt][7] = ss[9] - 'A';
            s[cnt][8] = ss[10] - 'A';
 
            int t1 = ss[1] - 'A';
            l[t1] = max(l[t1], 1);
            int t2 = ss[6] - 'A';
            r[t2] = min(r[t2], 1);
            int t3 = ss[9] - 'A';
            r[t3] = min(r[t3], 3);
        }
 
        dfs(0);
        /*
        if(ff) {
            f = true;
            for(int i = 1; i <= cnt; i++) {
                int y = 0, m = 0, d = 0;
                for(int j = 1; j <= 4; j++) y = y * 10 + to[s[i][j]];
                for(int j = 5; j <= 6; j++) m = m * 10 + to[s[i][j]];
                for(int j = 7; j <= 8; j++) d = d * 10 + to[s[i][j]];
                if(y < 1600 || y > 9999 || m > 12 || d > 31) {
                    f = false;
                    break;
                }
                if(!caile(y, m, d)) {
                    f = false;
                    break;
                }
            }
        }*/
        printf("Case #%d: ", ++cas);
        if(ff) {
            for(int i = 0; i < 10; i++) printf("%d", to[i]);
            puts("");
        } else puts("Impossible");
    } 
   return 0;
}

J

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int n, m;
int c[1005][1005];
int d[1005];
ll sum[1005][1005];
int mb[1005][1005];
 
int main() {
    int T;
    int cas = 0;
    scanf("%d", &T);
    while(T--) {
        cas++;
        scanf("%d%d", &n, &m);
        for(int i = 1; i <= n; i++) {
            sum[i][0] = 0;
            for(int j = 1; j <= m; j++) {
                scanf("%d", &c[i][j]);
                sum[i][j] = sum[i][j - 1] + 1LL * c[i][j];
            }
            mb[i][m] = m;
            for(int j = m - 1; j >= 0; j--) {
                if(sum[i][j] > sum[i][mb[i][j + 1]])
                    mb[i][j] = mb[i][j + 1];
                else mb[i][j] = j;
            }
        }
        d[0] = 0;
        ll ans = 0;
        ll ssum = 0;
        ll tmp = 0;
        for(int i = 1; i <= m; i++) scanf("%d", &d[i]);
        for(int j = 0; j <= m; j++) {
            tmp += 1LL * d[j];
            ssum = 0;
            int cn = 0;
            ll zx = 1e13;
            for(int i = 1; i <= n; i++) {
                int t = mb[i][j];
                ssum += sum[i][t];
                if(t > j) {
                    cn++;
                    zx = min(zx, sum[i][j] - sum[i][t]);
                }
            }
            if(cn == n) ans = max(ans, tmp - ssum - zx);
            else ans = max(ans, tmp - ssum);
        }
        printf("Case #%d: ", cas);
        printf("%lld\n", ans);
    }
 
    return 0;
}
posted @ 2019-08-05 21:41  kpole  阅读(235)  评论(0编辑  收藏  举报