結果

問題 No.440 2次元チワワ問題
ユーザー tana_twtrtana_twtr
提出日時 2016-10-29 14:16:18
言語 Ruby
(3.3.0)
結果
RE  
実行時間 -
コード長 1,092 bytes
コンパイル時間 57 ms
コンパイル使用メモリ 7,296 KB
実行使用メモリ 19,584 KB
最終ジャッジ日時 2024-05-03 15:46:32
合計ジャッジ時間 8,835 ms
ジャッジサーバーID
(参考情報)
judge4 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 RE -
testcase_01 RE -
testcase_02 RE -
testcase_03 RE -
testcase_04 RE -
testcase_05 RE -
testcase_06 RE -
testcase_07 RE -
testcase_08 RE -
testcase_09 RE -
testcase_10 RE -
testcase_11 RE -
testcase_12 RE -
testcase_13 RE -
testcase_14 RE -
testcase_15 RE -
testcase_16 RE -
testcase_17 RE -
testcase_18 RE -
testcase_19 TLE -
testcase_20 -- -
testcase_21 -- -
testcase_22 -- -
testcase_23 -- -
testcase_24 -- -
testcase_25 -- -
権限があれば一括ダウンロードができます
コンパイルメッセージ
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 y, x, -1, 0, a, b, c, d
   total += search_w_dir y, x, 1, 0, a, b, c, d
   total += search_w_dir y, x, 0, -1, a, b, c, d
   total += search_w_dir 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