結果
問題 |
No.113 宝探し
|
ユーザー |
![]() |
提出日時 | 2016-03-23 18:38:54 |
言語 | Java (openjdk 23) |
結果 |
AC
|
実行時間 | 117 ms / 5,000 ms |
コード長 | 1,049 bytes |
コンパイル時間 | 3,083 ms |
コンパイル使用メモリ | 78,032 KB |
実行使用メモリ | 41,564 KB |
最終ジャッジ日時 | 2024-11-16 21:11:53 |
合計ジャッジ時間 | 6,785 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 23 |
ソースコード
import java.util.Scanner; import java.util.HashMap; public class yukicoder_113 { public static void main(String[] args) { Scanner stdIn = new Scanner(System.in); String str = stdIn.next(); String[] array = new String[str.length()]; HashMap<String, Integer> map = new HashMap<String, Integer>(); map.put(str.substring(0, 1), 1); for (int i = 1; i < array.length; i++) { array[i] = str.substring(i, i + 1); if (map.containsKey(array[i])) { map.put(array[i], map.get(array[i]) + 1); } else { map.put(array[i], 1); } } int north = 0, east = 0, west = 0, south = 0; if (map.get("N") != null) { north = map.get("N") * 1; } if (map.get("E") != null) { east = map.get("E") * 1; } if (map.get("W") != null) { west = map.get("W") * (-1); } if (map.get("S") != null) { south = map.get("S") * (-1); } double height = Math.pow(Math.abs(north + south),2); double width = Math.pow(Math.abs(east + west),2); System.out.println(Math.sqrt(height + width)); } }