結果

問題 No.440 2次元チワワ問題
ユーザー tana_twtrtana_twtr
提出日時 2016-10-29 14:25:09
言語 Ruby
(3.3.0)
結果
TLE  
実行時間 -
コード長 1,104 bytes
コンパイル時間 117 ms
コンパイル使用メモリ 7,552 KB
実行使用メモリ 25,984 KB
最終ジャッジ日時 2024-11-24 17:53:28
合計ジャッジ時間 105,593 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 76 ms
17,536 KB
testcase_01 AC 76 ms
24,832 KB
testcase_02 AC 76 ms
25,984 KB
testcase_03 AC 77 ms
24,960 KB
testcase_04 AC 144 ms
17,536 KB
testcase_05 AC 91 ms
24,576 KB
testcase_06 AC 81 ms
24,832 KB
testcase_07 TLE -
testcase_08 TLE -
testcase_09 TLE -
testcase_10 TLE -
testcase_11 TLE -
testcase_12 TLE -
testcase_13 TLE -
testcase_14 AC 702 ms
17,536 KB
testcase_15 TLE -
testcase_16 AC 835 ms
18,944 KB
testcase_17 TLE -
testcase_18 TLE -
testcase_19 TLE -
testcase_20 TLE -
testcase_21 TLE -
testcase_22 TLE -
testcase_23 TLE -
testcase_24 TLE -
testcase_25 TLE -
権限があれば一括ダウンロードができます
コンパイルメッセージ
Main.rb:3: warning: assigned but unused variable - w
Syntax OK

ソースコード

diff #

def main
    lines = STDIN.readlines
    h, w = lines[0].split.map {|x| x.to_i}
    s = []
    h.times {|i| s << lines[i + 1].chomp}
    q = lines[h + 1].chomp.to_i
    q_array = []
    q.times {|i| q_array << lines[h + i + 2].split.map {|x| x.to_i - 1}.to_a}

    q_array.each do |a, b, c, d|
        
        total = 0
        
        a.upto(c) do |y|
            b.upto(d) do |x|
                if s[y][x] == "c"
                    total += search_w s, y, x, a, b, c, d
                end
            end
        end
        
        puts total

    end
end

def search_w(s, y, x, a, b, c, d)
   
   total = 0
   total += search_w_dir s, y, x, -1, 0, a, b, c, d
   total += search_w_dir s, y, x, 1, 0, a, b, c, d
   total += search_w_dir s, y, x, 0, -1, a, b, c, d
   total += search_w_dir s, y, x, 0, 1, a, b, c, d
   total

end

def search_w_dir(s, y, x, j, i, a, b, c, d)
    
    w_count = 0

    while a <= y && y <= c && b <= x && x <= d
        if s[y][x] == "w"
            w_count += 1
        end

        y += j
        x += i
    end

    w_count * (w_count - 1) / 2
    
end

main()

0