結果
| 問題 |
No.139 交差点
|
| コンテスト | |
| ユーザー |
uafr_cs
|
| 提出日時 | 2015-08-17 04:00:59 |
| 言語 | Java (openjdk 23) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,398 bytes |
| コンパイル時間 | 1,892 ms |
| コンパイル使用メモリ | 78,432 KB |
| 実行使用メモリ | 54,388 KB |
| 最終ジャッジ日時 | 2024-07-18 09:57:57 |
| 合計ジャッジ時間 | 6,789 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 21 WA * 7 |
ソースコード
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.HashSet;
import java.util.LinkedList;
import java.util.Scanner;
import java.util.Set;
public class Main {
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
final int N = sc.nextInt();
final long L = sc.nextLong();
int[] xs = new int[N];
int[] ws = new int[N];
long[] Ts = new long[N];
for(int i = 0; i < N; i++){
final int x = sc.nextInt();
final int w = sc.nextInt();
final long T = sc.nextLong();
xs[i] = x;
ws[i] = w;
Ts[i] = T;
}
int time = 0;
int pos = 0;
for(int i = 0; i < N; i++){
final int arrival_time = time + (xs[i] - pos);
final int throught_time = arrival_time + ws[i];
if(arrival_time % (2 * Ts[i]) > Ts[i]){
final int arrival_wait_time = (int) ((arrival_time + (2 * Ts[i]) - 1) / (2 * Ts[i]) * (2 * Ts[i]));
time = arrival_wait_time + ws[i];
}else if(throught_time % (2 * Ts[i]) >= Ts[i]){
//System.out.println(throught_time);
final int arrival_wait_time = (int) ((throught_time + (2 * Ts[i]) - 1) / (2 * Ts[i]) * (2 * Ts[i]));
//System.out.println(arrival_wait_time);
time = arrival_wait_time + ws[i];
}else{
time = throught_time;
}
pos = xs[i] + ws[i];
}
time += L - (xs[N - 1] + ws[N - 1]);
System.out.println(time);
}
}
uafr_cs