⬆︎
×

[PAT-A] 1056 Mice and Rice

Hyplus目录

Java

import java.io.*;
import java.util.*;

public class Main {
    static final int N = 1010;

    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st;

        st = new StringTokenizer(br.readLine());
        int n = Integer.parseInt(st.nextToken());  // 老鼠数量
        int m = Integer.parseInt(st.nextToken());  // 每轮最多参与的老鼠数量
        int[] w = new int[N];       // 每只老鼠的权重
        int[] ans = new int[N];     // 每只老鼠的级别

        st = new StringTokenizer(br.readLine());
        for (int i = 0; i < n; i++) {
            w[i] = Integer.parseInt(st.nextToken());
        }

        List<Integer> cur = new ArrayList<>();
        st = new StringTokenizer(br.readLine());
        for (int i = 0; i < n; i++) {
            cur.add(Integer.parseInt(st.nextToken()));
        }

        while (cur.size() > 1) {
            List<Integer> next = new ArrayList<>();
            int remain = (cur.size() + m - 1) / m;  // 每次剩下 "n/m" 只老鼠,需取模

            for (int i = 0; i < cur.size(); ) {
                int j = Math.min(cur.size(), i + m);

                int t = i;
                for (int k = i; k < j; k++) {
                    if (w[cur.get(k)] > w[cur.get(t)]) {
                        t = k;
                    }
                }
                next.add(cur.get(t));
                for (int k = i; k < j; k++) {
                    if (k != t) {
                        ans[cur.get(k)] = remain + 1;
                    }
                }

                i = j;
            }

            cur = next;
        }

        ans[cur.get(0)] = 1;

        System.out.print(ans[0]);
        for (int i = 1; i < n; i++) {
            System.out.print(" " + ans[i]);
        }
        System.out.println();

        br.close();
    }
}

C++

#include <iostream>
#include <cstring>
#include <algorithm>
#include <vector>

using namespace std;

const int N = 1010;

int n, m;
int w[N], ans[N];

int main() {
    cin >> n >> m;
    for (int i = 0; i < n; i++) cin >> w[i];
    vector<int> cur(n);

    for (int i = 0; i < n; i++) cin >> cur[i];

    while ((int) cur.size() > 1) {
        vector<int> next;
        int remain = (cur.size() + m - 1) / m;    // 每次剩下"n/m"只老鼠 需取模

        for (int i = 0; i < cur.size();) {
            int j = min((int) cur.size(), i + m);

            int t = i;
            for (int k = i; k < j; k++)
                if (w[cur[k]] > w[cur[t]])
                    t = k;
            next.push_back(cur[t]);
            for (int k = i; k < j; k++)
                if (k != t)
                    ans[cur[k]] = remain + 1;

            i = j;
        }

        cur = next;
    }

    ans[cur[0]] = 1;

    cout << ans[0];
    for (int i = 1; i < n; i++) cout << ' ' << ans[i];
    cout << endl;

    return 0;
}

发表评论