結果
| 問題 |
No.139 交差点
|
| コンテスト | |
| ユーザー |
uafr_cs
|
| 提出日時 | 2015-08-17 15:48:40 |
| 言語 | Java (openjdk 23) |
| 結果 |
AC
|
| 実行時間 | 146 ms / 5,000 ms |
| コード長 | 1,235 bytes |
| コンパイル時間 | 2,234 ms |
| コンパイル使用メモリ | 78,276 KB |
| 実行使用メモリ | 54,396 KB |
| 最終ジャッジ日時 | 2024-07-18 10:01:17 |
| 合計ジャッジ時間 | 6,481 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 28 |
ソースコード
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;
}
long total_time = 0;
for(int i = 0; i < N; i++){
final long arrival_time = total_time + (xs[i] - (i == 0 ? 0 : (xs[i - 1] + ws[i - 1])));
final long walk_time = Math.max(0, Ts[i] - arrival_time % (2 * Ts[i]));
if(walk_time >= ws[i]){
total_time = arrival_time + ws[i];
}else{
final long arrival_wait_time = (arrival_time + (2 * Ts[i] - 1)) / (2 * Ts[i]) * (2 * Ts[i]);
total_time = arrival_wait_time + ws[i];
}
//System.out.println(arrival_time + " " + walk_time + " " + total_time);
}
total_time += (L - (xs[N - 1] + ws[N - 1]));
System.out.println(total_time);
}
}
uafr_cs