結果

問題 No.113 宝探し
ユーザー maru
提出日時 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
権限があれば一括ダウンロードができます

ソースコード

diff #

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));
	}
}
0