結果
| 問題 | No.154 市バス |
| コンテスト | |
| ユーザー |
kaiyori_lab
|
| 提出日時 | 2015-02-18 02:08:14 |
| 言語 | D (dmd 2.109.1) |
| 結果 |
AC
|
| 実行時間 | 157 ms / 2,000 ms |
| コード長 | 1,008 bytes |
| コンパイル時間 | 817 ms |
| コンパイル使用メモリ | 100,076 KB |
| 実行使用メモリ | 6,944 KB |
| 最終ジャッジ日時 | 2024-06-12 02:23:24 |
| 合計ジャッジ時間 | 2,278 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 8 |
ソースコード
import std.stdio;
import std.string;
import std.conv;
import std.algorithm;
import std.range;
import std.array;
import std.typecons;
import std.random;
bool cityBus(string s, int[] routes = []){
if(!s.length) return routes.reduce!min >= 3;
auto tail = s.back.to!char;
s = s[0..$-1];
/// ***R --------------------------
if(tail == 'R'){
return cityBus(s, routes ~= 1);
}
/// ****G ------------------------
else if(tail == 'G'){
foreach(ref r; routes){
if(r == 1){
r += 1;
return cityBus(s, routes);
}
}
return false;
}
/// ***W -----------------------
else{
foreach(ref r; routes){
if(r == 2){
r += 1;
return cityBus(s, routes);
}
}
foreach(ref r; routes){
if(r > 2){
r += 1;
return cityBus(s, routes);
}
}
return false;
}
}
void main(){
immutable N = readln.strip.to!int;
foreach(i; 0..N) writeln( cityBus(readln.strip) ? "possible" : "impossible" );
}
kaiyori_lab