LoginSignup
2
0

More than 1 year has passed since last update.

概要

表題のプログラミング言語でAtCoder Beginners Selectionを実施記録した際の記録です
基本文法の学習が目的です

https://atcoder.jp/contests/abs
AtCoder Beginners Selectionとは?
このコンテストは、「AtCoderに登録したけど何をしていいか分からない・・・!」という人に向けて作られた、初心者向け問題集です。
問題は、dr.kenさんの、「AtCoder に登録したら次にやること ~ これだけ解けば十分闘える!過去問精選 10 問 ~」から選出しています。

基本的には以下ができれば大体の問題を解けるようになっている。

  • 標準入力
  • 標準出力
  • 四則演算
  • 条件分岐
  • 文字列操作
  • ループ
  • 配列の操作
  • 全通りの探索
  • 組み込み関数等の利用
  • ソート
  • 集合
  • 二次元配列の操作

PracticeA - Welcome to AtCoder

PracticeA - Welcome to AtCoder

問題文
高橋君はデータの加工が行いたいです。
整数 a,b,cと、文字列 s が与えられます。 a+b+c の計算結果と、文字列 s を並べて表示しなさい。

制約
1≤a,b,c≤1,000
1≤∣s∣≤100

入力
入力は以下の形式で与えられる。
a
b c
s

出力
a+b+c と s を空白区切りで 1 行に出力せよ。

基本的な標準入力、標準出力、四則演算ができればOK

main.rb
# 変数a,b,c,sを宣言します。
a = gets.to_i
b,c = gets.split.map(&:to_i)
s = gets.chomp

# a+b+cの計算結果と、文字列sを空白区切りで出力します。
puts "#{a+b+c} #{s}"

ABC086A - Product

ABC086A - Product

問題文
シカのAtCoDeerくんは二つの正整数 a,b を見つけました。 a と b の積が偶数か奇数か判定してください。

制約
1 ≤ a,b ≤ 10000
a,b は整数

入力
入力は以下の形式で標準入力から与えられる。
a b

出力
積が奇数なら Odd と、 偶数なら Even と出力せよ。

基本的な標準入力、標準出力、四則演算、条件分岐ができればOK

main.rb
a, b = gets.split.map(&:to_i) # a, bを入力から取得し、整数型に変換する

if a * b % 2 == 0 # a * bが偶数かどうか
  puts "Even"
else
  puts "Odd"
end

ABC081A - Placing Marbles

ABC081A - Placing Marbles

問題文
すぬけ君は 1,2,3 の番号がついた 3 つのマスからなるマス目を持っています。各マスには 0 か 1 が書かれており、マス i には si が書かれています。
すぬけ君は 1 が書かれたマスにビー玉を置きます。 ビー玉が置かれるマスがいくつあるか求めてください。

制約
s1 ,s2 ,s3 は 1 あるいは 0

入力
入力は以下の形式で標準入力から与えられる。
s1s2s3

出力
答えを出力せよ。

入力例 1
101

出力例 1
2

基本的な標準入力、標準出力、文字列操作ができればOK

main.rb
# 標準入力から文字列を取得
s = gets

# 文字列中の '1' の数を数える
num_ones = s.count("1")

# 答えを出力
puts num_ones

ABC081B - Shift only

ABC081B - Shift only

問題文
黒板に N 個の正の整数 A1,...,AN が書かれています.
すぬけ君は,黒板に書かれている整数がすべて偶数であるとき,次の操作を行うことができます.
黒板に書かれている整数すべてを,2 で割ったものに置き換える.
すぬけ君は最大で何回操作を行うことができるかを求めてください.

制約
1≤N≤200
1≤Ai≤10^9

入力
入力は以下の形式で標準入力から与えられる。
N
A1 A2 ... AN

出力
すぬけ君は最大で何回操作を行うことができるかを出力せよ.

入力例 1
3
8 12 40

出力例 1
2

基本的な標準入力、標準出力、四則演算、ループ、条件分岐、配列の操作ができればOK

main.rb
# N個の整数を読み込む
n = gets.to_i
# N個の整数を配列として読み込む
numbers = gets.split.map(&:to_i)

# 最小操作回数を保存する変数
min_operation = 1e9

# 整数の配列を順に処理する
numbers.each do |number|
  # 現在の整数が2で割り切れる回数
  operation = 0

  # 現在の整数が2で割り切れるかどうかを確認する
  while number % 2 == 0
    # 現在の整数を2で割る
    number /= 2
    # 割り切れた回数をカウントする
    operation += 1
  end

  # 最小操作回数を更新する
  min_operation = [min_operation, operation].min
end

# 最小操作回数を出力する
puts min_operation

ABC087B - Coins

ABC087B - Coins

問題文
あなたは、500 円玉を A 枚、100 円玉を B 枚、50 円玉を C 枚持っています。 これらの硬貨の中から何枚かを選び、合計金額をちょうど X 円にする方法は何通りありますか。
同じ種類の硬貨どうしは区別できません。2 通りの硬貨の選び方は、ある種類の硬貨についてその硬貨を選ぶ枚数が異なるとき区別されます。

制約
0≤A,B,C≤50
A+B+C≥1
50≤X≤20,000
A,B,C は整数である
X は 50 の倍数である

入力
入力は以下の形式で標準入力から与えられる。
A
B
C
X

出力
硬貨を選ぶ方法の個数を出力せよ。

基本的な標準入力、標準出力、四則演算、ループ、条件分岐、配列の操作、全通りの探索ができればOK

main.rb
a = gets.to_i
b = gets.to_i
c = gets.to_i
x = gets.to_i

count = 0
(0..a).each do |i|
  (0..b).each do |j|
    (0..c).each do |k|
      count += 1 if i * 500 + j * 100 + k * 50 == x
    end
  end
end

puts count

ABC083B - Some Sums

ABC083B - Some Sums

問題文
1 以上 N 以下の整数のうち、10 進法での各桁の和が A 以上 B 以下であるものの総和を求めてください。

制約
1≤N≤10^4
1≤A≤B≤36
入力はすべて整数である

入力
入力は以下の形式で標準入力から与えられる。
N A B

出力
1 以上 N 以下の整数のうち、10 進法での各桁の和が A 以上 B 以下であるものの総和を出力せよ。

基本的な標準入力、標準出力、四則演算、ループ、条件分岐、配列の操作、組み込み関数の利用、ができればOK

main.rb
# 入力値を受け取る
n, a, b = gets.split.map(&:to_i)

# 答えを格納する変数を定義
ans = 0

# 1からnまでの整数を順に処理する
1.upto(n) do |i|
  # iを10進法で表した際の各桁の和を求める
  sum = i.to_s.split('').map(&:to_i).inject(:+)

  # 各桁の和がA以上B以下である場合、答えに加算する
  ans += i if a <= sum && sum <= b
end

# 答えを出力する
puts ans

ABC088B - Card Game for Two

ABC088B - Card Game for Two

問題文
N 枚のカードがあります. i 枚目のカードには, ai という数が書かれています.
Alice と Bob は, これらのカードを使ってゲームを行います. ゲームでは, Alice と Bob が交互に 1 枚ずつカードを取っていきます. Alice が先にカードを取ります.
2 人がすべてのカードを取ったときゲームは終了し, 取ったカードの数の合計がその人の得点になります. 2 人とも自分の得点を最大化するように最適な戦略を取った時, Alice は Bob より何点多く取るか求めてください.

制約
N は 1 以上 100 以下の整数
ai(1≤i≤N) は 1 以上 100 以下の整数

入力
入力は以下の形式で標準入力から与えられる.
N
a1 a2 a3 ... aN

出力
両者が最適な戦略を取った時, Alice は Bob より何点多く取るかを出力してください.

基本的な標準入力、標準出力、四則演算、条件分岐、配列の操作、ループ、ソート、ができればOK

main.rb
n = gets.chomp.to_i
m = gets.chomp.split(' ').map(&:to_i).sort.reverse
alice = 0
bob = 0

m.each_with_index do |n, i|
  if i.even?
    alice += n
  else
    bob += n
  end
end

puts alice - bob

ABC085B - Kagami Mochi

ABC085B - Kagami Mochi

問題文
X 段重ねの鏡餅 (X≥1) とは、X 枚の円形の餅を縦に積み重ねたものであって、どの餅もその真下の餅より直径が小さい(一番下の餅を除く)もののことです。例えば、直径 10、8、6 センチメートルの餅をこの順に下から積み重ねると 3 段重ねの鏡餅になり、餅を一枚だけ置くと 1 段重ねの鏡餅になります。
ダックスフンドのルンルンは N 枚の円形の餅を持っていて、そのうち i 枚目の餅の直径は diセンチメートルです。これらの餅のうち一部または全部を使って鏡餅を作るとき、最大で何段重ねの鏡餅を作ることができるでしょうか。

制約
1≤N≤100
1≤di≤100
入力値はすべて整数である。

入力
入力は以下の形式で標準入力から与えられる。
N
d1
​:
dN

​出力
作ることのできる鏡餅の最大の段数を出力せよ。

入力例 1
4
10
8
8
6

出力例 1
3

基本的な標準入力、標準出力、四則演算、ループ、配列、集合、ができればOK

main.rb
# 入力を受け取る
n = gets.to_i
d = n.times.map { gets.to_i }

# 餅を昇順に並べる
d.sort!

# 最大の段数を計算する
ans = 1
previous_diameter = d[0]

d.each do |current_diameter|
  if current_diameter > previous_diameter
    ans += 1
    previous_diameter = current_diameter
  end
end
# 答えを出力する
puts ans

ABC085C - Otoshidama

ABC085C - Otoshidama

問題文
日本でよく使われる紙幣は、10000 円札、5000 円札、1000 円札です。以下、「お札」とはこれらのみを指します。
青橋くんが言うには、彼が祖父から受け取ったお年玉袋にはお札が N 枚入っていて、合計で Y 円だったそうですが、嘘かもしれません。このような状況がありうるか判定し、ありうる場合はお年玉袋の中身の候補を一つ見つけてください。なお、彼の祖父は十分裕福であり、お年玉袋は十分大きかったものとします。

制約
1≤N≤2000
1000≤Y≤2×10^7
N は整数である。
Y は 1000 の倍数である。

入力
入力は以下の形式で標準入力から与えられる。
N Y

出力
N 枚のお札の合計金額が Y 円となることがありえない場合は、-1 -1 -1 と出力せよ。
N 枚のお札の合計金額が Y 円となることがありうる場合は、そのような N 枚のお札の組み合わせの一例を「10000 円札 x 枚、5000 円札 y 枚、1000 円札 z 枚」として、x、y、z を空白で区切って出力せよ。複数の可能性が考えられるときは、そのうちどれを出力してもよい。

入力例 1
9 45000

出力例 1
4 0 5

基本的な標準入力、標準出力、四則演算、ループができればOK

main.rb
# 与えられた入力を読み取る
n, yy = gets.chomp.split(" ").map(&:to_i)

# 10000 円札、5000 円札、1000 円札の可能な組み合わせから、条件を満たす解を探す
(0..n).each do |x|
  (0..n-x).each do |y|
    z = n - x - y
    if 10000 * x + 5000 * y + 1000 * z == yy
      puts "#{x} #{y} #{z}"
      exit
    end
  end
end

# 条件を満たす解が見つからない場合は、-1 -1 -1 を出力する
puts "-1 -1 -1"

ABC049C - 白昼夢

ABC049C - 白昼夢

問題文
英小文字からなる文字列 S が与えられます。 Tが空文字列である状態から始め、以下の操作を好きな回数繰り返すことで S=T とすることができるか判定してください。

制約
1≦∣S∣≦10^5
S は英小文字からなる。

入力
入力は以下の形式で標準入力から与えられる。
S

出力
S=T とすることができる場合 YES を、そうでない場合 NO を出力せよ。

入力例 1
erasedream

出力例 1
YES

基本的な標準入力、標準出力、文字列操作ができればOK

main.rb
s = gets.chomp
ok = true
s_rev = s.reverse!
while s_rev.length > 0
  if s_rev.start_with?("maerd")
    s_rev.slice!("maerd")
  elsif s_rev.start_with?("remaerd")
    s_rev.slice!("remaerd")
  elsif s_rev.start_with?("esare")
    s_rev.slice!("esare")
  elsif s_rev.start_with?("resare")
    s_rev.slice!("resare")
  else
    ok = false
    break
  end
end
puts ok ? "YES" : "NO"

ABC086C - Traveling

ABC086C - Traveling

問題文
シカのAtCoDeerくんは二次元平面上で旅行をしようとしています。 AtCoDeerくんの旅行プランでは、時刻 0 に 点 (0,0) を出発し、 1 以上 N 以下の各 i に対し、時刻tiに 点 (xi,yi) を訪れる予定です。
AtCoDeerくんが時刻 t に 点 (x,y) にいる時、 時刻 t+1 には 点 (x+1,y), (x−1,y), (x,y+1), (x,y−1) のうちいずれかに存在することができます。 その場にとどまることは出来ないことに注意してください。 AtCoDeerくんの旅行プランが実行可能かどうか判定してください。

制約
1 ≤ N ≤ 10^5
0 ≤ xi ≤ 10^5
0 ≤ yi ≤ 10^5
1 ≤ ti ≤ 10^5
ti < ti+1 (1 ≤ i ≤ N−1)
入力は全て整数

入力
入力は以下の形式で標準入力から与えられる。
N
t1 x1 y1
​t2 x2 y2
:
tN xN yN

出力
旅行プランが実行可能ならYesを、不可能ならNoを出力してください。

入力例 1
2
3 1 2
6 1 1

出力例 1
Yes

入力例 2
1
2 100 100

出力例 2
No
(0,0) にいる状態から 2 秒後に (100,100) にいるのは不可能です。

入力例 3
2
5 1 1
100 1 1

出力例 3
No

基本的な標準入力、標準出力、四則演算、ループ、二次元配列の操作、ができればOK

main.rb
# スタート地点を表す配列
start = [0, 0, 0]

# 入力からNを取得する
n = gets.to_i

# N回繰り返す
n.times do |i|
  # t, x, yを入力から取得する
  t, x, y = gets.split.map(&:to_i)

  # 現在地から目的地までの移動時間が1より大きい場合はNoを出力してプログラムを終了する
  # AtCoDeerくんが移動可能かどうかを判定する
  if (x - start[1]).abs + (y - start[2]).abs > t - start[0] || (t - start[0] - (x - start[1]).abs - (y - start[2]).abs) % 2 != 0
    puts "No"
    exit
  end

  # 目的地を現在地とする
  start = [t, x, y]
end

# 全ての移動が実行可能だった場合はYesを出力する
puts "Yes"

参考

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0