カテゴリ: Ruby 更新日: 2026/02/02

Rubyでべき乗・剰余・商と余りを理解する!**・%・divmodの実用サンプル

べき乗・剰余・商と余り:**・%・divmod の実用サンプル
べき乗・剰余・商と余り:**・%・divmod の実用サンプル

先生と生徒の会話形式で理解しよう

生徒

「Rubyで数値を計算するとき、べき乗や余りを簡単に出す方法ってありますか?」

先生

「もちろんです。Rubyでは**でべき乗、%で剰余、さらにdivmodで商と余りをまとめて求められます。」

生徒

「それぞれどう違うんですか?使い分けも知りたいです。」

先生

「では、順番に実例を見ながら理解していきましょう。」

1. べき乗(**)の基本

1. べき乗(**)の基本
1. べき乗(**)の基本

べき乗は数値を何回掛けるかを示す演算です。例えば2の3乗なら、2を3回掛けた結果を求めます。


puts 2 ** 3   # 2の3乗
puts 5 ** 2   # 5の2乗

8
25

べき乗は指数計算や繰り返し掛け算の処理で便利です。

2. 剰余(%)の使い方

2. 剰余(%)の使い方
2. 剰余(%)の使い方

剰余演算子%は割り算の余りを求めるために使います。プログラムでは偶数・奇数判定や周期処理に非常に役立ちます。


puts 10 % 3  # 余り1
puts 8 % 2   # 偶数判定

1
0

0が返れば割り切れたことを意味します。周期処理やカウント処理の制御によく使われます。

3. 商と余りをまとめて求めるdivmod

3. 商と余りをまとめて求めるdivmod
3. 商と余りをまとめて求めるdivmod

divmodは割り算の結果を商と余りのセットで返すメソッドです。数値計算をまとめて行うのに便利です。


quotient, remainder = 10.divmod(3)
puts "商: #{quotient}, 余り: #{remainder}"

商: 3, 余り: 1

これを使えば、割り算と余りの計算を別々に行わなくても済みます。

4. 実用的な活用例

4. 実用的な活用例
4. 実用的な活用例

例えば、1週間を7日で割る場合や、時計の時間計算で剰余やdivmodを使えます。


# 時計の計算例
hour = 15
hour24 = hour % 12
puts "12時間表記: #{hour24}"

# お金の分配例
total = 1000
people = 3
quotient, remainder = total.divmod(people)
puts "一人当たり: #{quotient}円, 余り: #{remainder}円"

12時間表記: 3
一人当たり: 333円, 余り: 1円

このように、**%divmodを組み合わせると、数値計算を効率的に行えます。

5. まとめ

5. まとめ
5. まとめ

Rubyでは数値の計算を簡単に行うために、べき乗(**)、剰余(%)、divmodを活用できます。べき乗は指数計算、剰余は余りの判定、divmodは商と余りを同時に求めるため、プログラム内での計算処理や分配、時間計算などに非常に便利です。初心者でも実用例を通じて理解すると、数値演算の応用が広がります。

まとめ

まとめ
まとめ

Rubyにおける数値計算の世界は、基本的な四則演算(足し算、引き算、掛け算、割り算)だけではありません。今回学習した**べき乗(**)**、**剰余(%)**、そして**divmodメソッド**を使いこなすことで、より複雑なロジックを簡潔に、かつ効率的に記述できるようになります。プログラミングにおいて、計算は単に答えを出すだけでなく、その結果を「どう制御に活かすか」が重要です。

数値演算をマスターするためのポイント

まずは「べき乗」についてです。`2 ** 10` のように記述するだけで、1024という結果が瞬時に得られます。これはループ処理で掛け算を繰り返すよりも遥かに読みやすく、数学的なアルゴリズムを実装する際に欠かせません。次に「剰余(%)」は、実は最も頻繁に使われる演算子の一つです。「3の倍数のときだけ処理を変える」「配列のインデックスをループさせる」「曜日を算出する」といった場面で大活躍します。そして、商と余りを一挙に取得できる「divmod」は、Rubyらしい非常に洗練されたメソッドです。

実際のデータベース操作と組み合わせた応用例

例えば、ECサイトの在庫管理システムを想像してみましょう。大量の商品を「1箱12個入り」のケースで発送する場合、何ケース必要で、バラの商品がいくつ残るかを計算する必要があります。SQLでデータを取得し、Ruby側で計算処理を行う流れを見てみましょう。

対象となる「products」テーブルのデータは以下の通りです。


id | product_name | stock_count | box_size
---+--------------+-------------+---------
1  | プレミアムリンゴ | 50          | 12
2  | 特選みかん     | 100         | 24
3  | 完熟メロン     | 15          | 4
4  | 白桃缶詰       | 33          | 6
5  | 高級巨峰       | 20          | 8
6  | 熟成栗        | 85          | 20

このデータに対して、在庫数(stock_count)を箱のサイズ(box_size)で割り、箱数と端数を算出するプログラムを記述します。


# データベースから取得したと仮定した配列データ
products = [
  { name: "プレミアムリンゴ", stock: 50, size: 12 },
  { name: "特選みかん", stock: 100, size: 24 },
  { name: "完熟メロン", stock: 15, size: 4 },
  { name: "白桃缶詰", stock: 33, size: 6 }
]

products.each do |p|
  boxes, leftovers = p[:stock].divmod(p[:size])
  puts "#{p[:name]}: #{boxes}箱 と 余り#{leftovers}個"
end

プレミアムリンゴ: 4箱 と 余り2個
特選みかん: 4箱 と 余り4個
完熟メロン: 3箱 と 余り3個
白桃缶詰: 5箱 と 余り3個

このように、divmodを使うことで変数への代入を一行で済ませることができ、コードの可読性が格段に向上します。

SQLでの剰余計算(おまけ)

実は、Rubyだけでなくデータベース(SQL)側でも剰余を求めることができます。例えば、IDが偶数のユーザーだけを抽出したい場合は以下のように記述します。


id | user_name | points
---+-----------+-------
1  | 佐藤      | 1500
2  | 鈴木      | 2400
3  | 高橋      | 800
4  | 田中      | 3200
5  | 伊藤      | 1100
6  | 渡辺      | 4500

SELECT id, user_name
FROM users
WHERE id % 2 = 0;

id | user_name
---+-----------
2  | 鈴木
4  | 田中
6  | 渡辺

SQLとRuby、それぞれの得意な場所で演算を使い分けるのがエンジニアの腕の見せ所ですね。

先生と生徒の振り返り会話

生徒

「先生、ありがとうございました!`**` や `%` がこんなに便利だとは思いませんでした。特に `divmod` は、今まで割り算と余りを別々に書いていたので、目から鱗です。」

先生

「そう言ってもらえると嬉しいです。特に剰余(%)は、プログラミング初学者の方が『いつ使うの?』と疑問に思いやすい部分ですが、実は交互に色を変えるテーブル行の実装や、ページネーションの計算など、フロントエンドからバックエンドまで至る所で使われているんですよ。」

生徒

「たしかに、2で割った余りが0か1かで、偶数・奇数を判定するのはよく見かけますね!ちなみに、べき乗を使ってすごく大きな数になったとき、Rubyは大丈夫なんですか?」

先生

「良い質問ですね。Rubyは非常に大きな整数も自動的に扱ってくれる『多倍長整数』をサポートしているので、メモリが許す限り、かなり巨大なべき乗の結果も正確に計算できますよ。他の言語だとオーバーフローを気にしないといけない場合も多いので、Rubyの優しい設計の一つですね。」

生徒

「そうなんですね。Rubyの柔軟さに助けられている部分が多い気がします。次はこれらの演算を使って、もう少し複雑なアルゴリズムにも挑戦してみたいです!」

先生

「その意気です。例えば、秒数を『時間・分・秒』に変換する処理などは、今回学んだ `divmod` を連鎖させて使うと非常に綺麗に書けます。ぜひ宿題として挑戦してみてくださいね。」

生徒

「はい!さっそくやってみます。ありがとうございました!」

カテゴリの一覧へ
新着記事
New1
Ruby
“すべてはオブジェクト”を体感!初心者向けRubyのオブジェクト指向入門【irbで学ぶ】
New2
Ruby
Rubyの標準入出力を完全ガイド!puts・print・pの違いとデバッグ活用法
New3
Ruby
Gemとは?RubyGemsとBundlerを初心者向けに完全解説!依存関係管理も図解でわかりやすく理解
New4
Ruby
Rubyの文字エンコーディング入門!UTF-8・マジックコメント・外部/内部エンコーディングを完全解説
人気記事
No.1
Java&Spring記事人気No1
Ruby
Rubyのreduceとinject入門!合計計算や集計を初心者向けに分かりやすく解説
No.2
Java&Spring記事人気No2
Ruby
Rubyの文字列エンコーディング完全ガイド!Encoding・force_encoding・encodeを初心者向け解説
No.3
Java&Spring記事人気No3
Ruby
Rubyの始め方ガイド:インストールから最初のHello Worldまで(Windows/Mac/Linux)
No.4
Java&Spring記事人気No4
データベース
PostgreSQLのWHERE句を徹底解説!初心者でもわかるSQLデータ抽出の基本
No.5
Java&Spring記事人気No5
Ruby
Rubyのfind/detect/find_indexを徹底解説!目的のデータを素早く探す方法
No.6
Java&Spring記事人気No6
Ruby
Rubyで比較演算子を完全解説!==・===・<=>・eql? の使い分け
No.7
Java&Spring記事人気No7
Ruby
Rubyのselect/reject/filterの使い方を完全解説!初心者向けの条件抽出レシピ
No.8
Java&Spring記事人気No8
データベース
PostgreSQLで順位付け!ROW_NUMBER関数の使い方を初心者向けに徹底解説