結果

問題 No.709 優勝可能性
コンテスト
ユーザー ei1333333
提出日時 2018-03-30 01:35:54
言語 Java
(openjdk 25.0.2)
コンパイル:
javac -encoding UTF8 _filename_
実行:
java -ea -Xmx700m -Xss256M -DONLINE_JUDGE=true _class_
結果
AC  
実行時間 1,560 ms / 3,500 ms
コード長 892 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 2,529 ms
コンパイル使用メモリ 81,984 KB
実行使用メモリ 92,036 KB
最終ジャッジ日時 2026-03-12 12:03:06
合計ジャッジ時間 16,466 ms
ジャッジサーバーID
(参考情報)
judge1_1 / judge3_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 22
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

import java.util.Scanner;

class Main
{
		public static void main(String arg[])
		{
				Scanner cin = new Scanner(System.in);
				int N = cin.nextInt();
				int M = cin.nextInt();
				int[][] R = new int[N][M];
				int[] last = new int[M];
				int[] deg = new int[N];
				int ans = 0;
			  
				for(int i = 0; i < N; i++) {
						for(int j = 0; j < M; j++) {
								R[i][j] = cin.nextInt();
								if(R[i][j] > R[last[j]][j]) {
										for(int k = last[j]; k < i; k++) {
												if(R[last[j]][j] == R[k][j]) {
														
														deg[k]--;
														if(deg[k] == 0) {
																ans--;
														}
												}
										}
										last[j] = i;
										deg[i]++;
										if(deg[i] == 1) ans++;
								} else if(R[i][j] == R[last[j]][j]) {
										deg[i]++;
										if(deg[i] == 1) ans++;
								}		
						}
						System.out.println(ans);
				}
		}
}
0