Submission #3582872


Source Code Expand

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.*;

public class Main {

    static int N, M;
    static int X0, A, P;

    public static void main(String[] args) {
        FastScanner sc = new FastScanner(System.in);
        N = sc.nextInt();
        M = sc.nextInt();
        X0 = sc.nextInt();
        A = sc.nextInt();
        P = sc.nextInt();

        System.out.println(solve());
    }

    static long solve() {
        if( A % P == 0 ) {
            if( X0 >= P ) {
                // X0, X0%P, X0%P...
                // 先頭を誰かと交代
                return 2 * (N-1);

            } else {
                // 全員同じ(X0)
                return 0;
            }
        }

        int x = X0;
        Student[] S = new Student[N*M];
        for (int i = 0; i < N; i++) {
            for (int j = 0; j < M; j++) {
                int idx = i*M+j;
                S[idx] = new Student(i, j, x);
                x = (x + A) % P;
            }
        }
        Arrays.sort(S, Comparator.comparingInt(s -> s.x));

        Student[] row = new Student[M];
        long ans = 0;
        for (int i = 0; i < N; i++) {
            long rowAns = 0;

            for (int j = 0; j < M; j++) {
                Student s = S[i*M+j];
                row[j] = s;
                if( s.i != i ) {
                    rowAns += Math.abs(s.i - i);
                }
            }

            Arrays.sort(row, Comparator.comparingInt(s -> s.j));

            for (int j = 0; j < M; j++) {
                rowAns += Math.abs(row[j].j - j);
            }

            ans += rowAns;
        }
        return ans;
    }

    static class Student {
        int i, j; // 元の位置
        int x; // 成績

        public Student(int i, int j, int x) {
            this.i = i;
            this.j = j;
            this.x = x;
        }
    }

    @SuppressWarnings("unused")
    static class FastScanner {
        private BufferedReader reader;
        private StringTokenizer tokenizer;

        FastScanner(InputStream in) {
            reader = new BufferedReader(new InputStreamReader(in));
            tokenizer = null;
        }

        String next() {
            if (tokenizer == null || !tokenizer.hasMoreTokens()) {
                try {
                    tokenizer = new StringTokenizer(reader.readLine());
                } catch (IOException e) {
                    throw new RuntimeException(e);
                }
            }
            return tokenizer.nextToken();
        }

        String nextLine() {
            if (tokenizer == null || !tokenizer.hasMoreTokens()) {
                try {
                    return reader.readLine();
                } catch (IOException e) {
                    throw new RuntimeException(e);
                }
            }
            return tokenizer.nextToken("\n");
        }

        long nextLong() {
            return Long.parseLong(next());
        }

        int nextInt() {
            return Integer.parseInt(next());
        }

        int[] nextIntArray(int n) {
            int[] a = new int[n];
            for (int i = 0; i < n; i++)
                a[i] = nextInt();
            return a;
        }

        long[] nextLongArray(int n) {
            long[] a = new long[n];
            for (int i = 0; i < n; i++)
                a[i] = nextLong();
            return a;
        }
    }
}

Submission Info

Submission Time
Task C - 席替え
User kusomushi
Language Java8 (OpenJDK 1.8.0)
Score 100
Code Size 3601 Byte
Status AC
Exec Time 209 ms
Memory 28628 KB

Judge Result

Set Name All
Score / Max Score 100 / 100
Status
AC × 82
Set Name Test Cases
All case_01.txt, case_02.txt, case_03.txt, case_04.txt, case_05.txt, case_06.txt, case_07.txt, case_08.txt, case_09.txt, case_10.txt, case_11.txt, case_12.txt, case_13.txt, case_14.txt, case_15.txt, case_16.txt, case_17.txt, case_18.txt, case_19.txt, case_20.txt, case_21.txt, case_22.txt, case_23.txt, case_24.txt, case_25.txt, case_26.txt, case_27.txt, case_28.txt, case_29.txt, case_30.txt, case_31.txt, case_32.txt, case_33.txt, case_34.txt, case_35.txt, case_36.txt, case_37.txt, case_38.txt, case_39.txt, case_40.txt, case_41.txt, case_42.txt, case_43.txt, case_44.txt, case_45.txt, case_46.txt, case_47.txt, case_48.txt, case_49.txt, case_50.txt, case_51.txt, case_52.txt, case_53.txt, case_54.txt, case_55.txt, case_56.txt, case_57.txt, case_58.txt, case_59.txt, case_60.txt, case_61.txt, case_62.txt, case_63.txt, case_64.txt, case_65.txt, case_66.txt, case_67.txt, case_68.txt, case_69.txt, case_70.txt, case_71.txt, case_72.txt, case_73.txt, case_74.txt, case_75.txt, case_76.txt, case_77.txt, case_78.txt, case_79.txt, sample_1.txt, sample_2.txt, sample_3.txt
Case Name Status Exec Time Memory
case_01.txt AC 179 ms 24788 KB
case_02.txt AC 181 ms 24276 KB
case_03.txt AC 178 ms 24660 KB
case_04.txt AC 163 ms 23764 KB
case_05.txt AC 179 ms 26196 KB
case_06.txt AC 169 ms 24020 KB
case_07.txt AC 157 ms 28116 KB
case_08.txt AC 155 ms 26196 KB
case_09.txt AC 190 ms 24660 KB
case_10.txt AC 186 ms 23508 KB
case_11.txt AC 174 ms 24788 KB
case_12.txt AC 174 ms 23252 KB
case_13.txt AC 183 ms 24660 KB
case_14.txt AC 187 ms 26068 KB
case_15.txt AC 196 ms 26580 KB
case_16.txt AC 192 ms 26196 KB
case_17.txt AC 193 ms 24148 KB
case_18.txt AC 172 ms 24276 KB
case_19.txt AC 189 ms 23252 KB
case_20.txt AC 185 ms 25428 KB
case_21.txt AC 183 ms 23636 KB
case_22.txt AC 166 ms 28628 KB
case_23.txt AC 184 ms 23508 KB
case_24.txt AC 186 ms 26196 KB
case_25.txt AC 163 ms 28244 KB
case_26.txt AC 196 ms 24788 KB
case_27.txt AC 180 ms 24532 KB
case_28.txt AC 157 ms 23892 KB
case_29.txt AC 184 ms 25552 KB
case_30.txt AC 173 ms 23116 KB
case_31.txt AC 177 ms 23636 KB
case_32.txt AC 162 ms 23636 KB
case_33.txt AC 176 ms 25684 KB
case_34.txt AC 192 ms 24148 KB
case_35.txt AC 178 ms 28500 KB
case_36.txt AC 190 ms 24532 KB
case_37.txt AC 161 ms 26068 KB
case_38.txt AC 173 ms 24660 KB
case_39.txt AC 195 ms 26580 KB
case_40.txt AC 185 ms 28244 KB
case_41.txt AC 190 ms 25428 KB
case_42.txt AC 167 ms 23636 KB
case_43.txt AC 174 ms 24020 KB
case_44.txt AC 164 ms 27988 KB
case_45.txt AC 182 ms 26320 KB
case_46.txt AC 183 ms 24660 KB
case_47.txt AC 180 ms 27604 KB
case_48.txt AC 159 ms 25812 KB
case_49.txt AC 166 ms 25556 KB
case_50.txt AC 199 ms 25808 KB
case_51.txt AC 192 ms 24276 KB
case_52.txt AC 198 ms 26324 KB
case_53.txt AC 194 ms 24532 KB
case_54.txt AC 199 ms 23632 KB
case_55.txt AC 193 ms 24276 KB
case_56.txt AC 200 ms 25812 KB
case_57.txt AC 193 ms 23124 KB
case_58.txt AC 201 ms 24020 KB
case_59.txt AC 193 ms 24276 KB
case_60.txt AC 205 ms 24276 KB
case_61.txt AC 205 ms 23892 KB
case_62.txt AC 204 ms 24236 KB
case_63.txt AC 205 ms 25940 KB
case_64.txt AC 208 ms 24916 KB
case_65.txt AC 202 ms 24532 KB
case_66.txt AC 207 ms 25296 KB
case_67.txt AC 205 ms 26068 KB
case_68.txt AC 200 ms 23244 KB
case_69.txt AC 209 ms 26408 KB
case_70.txt AC 73 ms 17748 KB
case_71.txt AC 74 ms 17492 KB
case_72.txt AC 73 ms 19924 KB
case_73.txt AC 74 ms 23124 KB
case_74.txt AC 73 ms 19156 KB
case_75.txt AC 74 ms 21076 KB
case_76.txt AC 73 ms 19668 KB
case_77.txt AC 74 ms 21332 KB
case_78.txt AC 74 ms 20948 KB
case_79.txt AC 75 ms 20948 KB
sample_1.txt AC 163 ms 23252 KB
sample_2.txt AC 170 ms 24660 KB
sample_3.txt AC 177 ms 26452 KB