商品サンプル画像
スッキリわかるJava入門 第3版 (スッキリわかる入門シリーズ)
商品ページ
Amazon
収益広告(手動登録)
商品サンプル画像
イナズマイレブン・ザ・ムービー 2025
商品ページ
Amazon
収益広告(自動登録)
※Amazonレビュー要確認
商品サンプル画像
鬼太郎誕生 ゲゲゲの謎 真生版
商品ページ
Amazon
収益広告(自動登録)
※Amazonレビュー要確認
商品サンプル画像
美男高校地球防衛部ETERNAL LOVE!
商品ページ
Amazon
収益広告(自動登録)
※Amazonレビュー要確認
商品サンプル画像
同じ月を見て
商品ページ
Amazon
収益広告(自動登録)
※Amazonレビュー要確認
記事の概要
【プログラミング】実例で分かるかもしれない再帰処理
作成日:2024-12-15
最終更新日:2024-12-15
記事の文字数:2874
情報技術プログラミング
本記事のトピック
  • 本ページは以下動画の台本を書き起こしたものです
  • 解説の趣旨・方向性
  • 再帰処理とはどういったものか
  • 実例「会社の部署構造をツリー構造にして取得する」から考えてみる
  • 基本的な考え方の整理
  • 再帰処理を使わない場合で考える
  • 再帰処理を使う場合で考える
  • まとめ
【プログラミング】実例で分かるかもしれない再帰処理
本ページは以下動画の台本を書き起こしたものです

解説の趣旨・方向性
皆さん、こんばんは
今回はプログラミングで「稀」に使われる再帰処理について、こちらのトピックに従って説明したいと思います
尚分かりやすいかどうかは個人差があります
一つ目のトピック、「解説の趣旨・方向性」は今お話しているところです。
「再帰処理とはどういったものか」のトピックでは簡単に再帰処理について説明します。この動画を見てる人はここだけ見ても分からないと思います
「実例「会社の部署構造をツリー構造にして取得する」から考えてみる」では実例を交えて説明します。本動画のメイントピックで、急いでいる人はここから見ればよいと思います
「まとめ」は最後の総括です。
それではやっていきましょう
再帰処理とはどういったものか
再帰処理とは一言で言うと「Aという処理の中で再びAという処理を呼び出す処理」です
例えば「データベースからユーザデータを取得する処理の中で、再び同じようにユーザを取得する処理を呼び出す」みたいなことをしたいときに用います
つまり処理中で自分自身を呼び出すわけですが、なぜそんなことをするのか
こちらを次項で説明します
実例「会社の部署構造をツリー構造にして取得する」から考えてみる
それでは実例をもとに再帰処理の使い方、そしてなぜ使うかを説明していきます
今回では「データベースに保存されている会社の部署構造をツリー構造にして取得する」というのを考えてみましょう
すなわちデータベースにこのように保存されている部署構造を……
このようにツリー構造に変換する、ということです。
テーブルの各行には一つ一つの部署名と親部署名の二つが保持されています
皆さんも自分ならどうするかを考えながら見てください
基本的な考え方の整理
さて、どのように取得するかは色々ありそうですが……
データベースには親部署の情報が含まれているので、単純に上の階層の部署から順番にどんどん下の階層の部署を取っていく方法が良さそうです
「会社」部署が一番上なのは分かり切ってるので、まず一番最初に「会社」部署が親となっている「管理部」「営業部」「製造部」を取得します
その次に「管理部」が親となっている「人事部」「経理部」「総務部」を取得します
同様に「営業部」「製造部」をそれぞれ親とする部署を取得します
このように見ると「対象部署を親とする部署を取得する」処理を何度も行っていることに気づけますね
フローチャートで描いてみましょう
シンプルなフローチャートですね。このフローが何度も行われているということです
このフローに便宜上「getChildDepartment」という名前を付けます。Departmentは部署という意味です
再帰処理を使わない場合で考える
似たような処理が何度も呼ばれているということは「getChildDepartment」という処理をループ文で呼び出せば解決できそうです
ボクは賢いんだ
「会社」部署は決まり切ってるので、まず最初に「会社」部署を親とする部署を取得します
あっ、コードは雰囲気で書いてるので雰囲気で読んでください
ここでは「管理部」「営業部」「製造部」が取得できるので、今度はこれらを親とする部署を取得するためにforループが必要ですね
そうそうこんな感じです
同じように今度はさらにこの処理で取得した部署を取得する必要があるので同じようなコードを書けばよいですね
おや?
for文を使ってるのに結局何度もgetChildDepartmentというメソッドがコード上に存在しています
この会社は3つ目の階層しかないのでこのコードで十分取得できますが、もし部署の階層が増えたらコードもまたさらにfor文を増やさないといけません
これはすごい歪な構造です。なにか変です、for文がマトリョーシカのような入れ子構造になっています
再帰処理を使う場合で考える
ここで出てくるのが再帰処理です
最初の部署のツリー構造もよくよく見ると同じ処理が入れ子構造になっています
このような時は再帰処理を疑うと良いでしょう
どうもこいつは再帰処理っぽい……そう考えた上で「getChildDepartment」のフローチャートを見てみます
さっきのフローチャートはこれほどシンプルでした
でも先ほどのツリー構造の図で重なり合っていた以上、ここは再帰処理で作ることができるはずです
まず取得した子の部署ひとつひとつに対して処理を行うため、ループ処理は入ってくるでしょう
そしてこのループ内で子の部署を取得します。子の部署を取得するというのはまさに「getChildDepartment」のことです
つまりフローチャートはこうなります
まさに「getChildDepartment」の中で「getChildDepartment」を呼び出す再帰処理になっています
ツリー構造の図と比較すると、この図がまさにそのままフローチャートになっていることに気づきます。
「getChildDepartment」の処理をこのように作っておけば、メインのフローもこのようにシンプルな構造にできます
いびつさを感じないフローになりましたね
まとめ
ということでまとめです
再帰処理とは「処理中で自分自身を呼び出す」処理のことを言う
同じような処理が続くのにループ文でうまく解決できないときに再帰処理を疑う
絵やフローチャートで描いたとき、同じような処理がマトリョーシカのような構造になっているときに再帰処理を疑う
以上、それではまたどこかでお会いしましょう
コメントログ
※コメントは最新50件が表示されます
コメント投稿




画面下部の「コンタクト」からも連絡可能です。
管理人ツイート
商品サンプル画像
鬼太郎誕生 ゲゲゲの謎 真生版
商品ページ
Amazon
収益広告(自動登録)
※Amazonレビュー要確認
商品サンプル画像
D.C.Ⅱ.S.S.~ダ・カーポⅡセカンドシーズン~(TV番組)
商品ページ
Amazon
非収益広告(手動登録)
商品サンプル画像
劇場版「鬼滅の刃」無限列車編
商品ページ
Amazon
収益広告(自動登録)
※Amazonレビュー要確認
商品サンプル画像
Dこそオンリーワン
商品ページ
Amazon
収益広告(自動登録)
※Amazonレビュー要確認
管理人作品宣伝
ぱらぱら工房
Webサイト / 最終更新:2025-03-26
jpegやpngなどの静止画画像ファイルを複数枚結合して、GIFやAPNG(アニメーシ…jpegやpngなどの静止画画像ファイルを複数枚結合して、GIFやAPNG(アニメーション付きPNG)を作成するだけのWebツールです。

HPで閲覧する利用素材等の詳細情報返礼特典
AIの考えた怖い話-Part01
動画 / 最終更新:2024-11-28
怪談系の怖い話を載せています。特に設定部分は人の手が入ってますが、なるべく生成AI(C…怪談系の怖い話を載せています。特に設定部分は人の手が入ってますが、なるべく生成AI(ChatGPT)を利用して書いています。

YouTubeで閲覧するニコニコ動画で閲覧する利用素材等の詳細情報
作品一覧はこちら
関連ページ
JavaScriptでアナログ時計とデジタル時計を表示するコード
最終更新日:2025-05-29
概要 最近アナログ時計を使ったので、アナログ時計を表示するJavaScriptコードを載せます。 …
記事を閲覧する
three.js・three-vrm.jsを使用して、VRoidをWebページ上に表示する Part-03
最終更新日:2025-04-20
概要 three.js・three-vrm.jsを使用して、VRoidをWebページ上に表示する方…
記事を閲覧する
three.js・three-vrm.jsを使用して、VRoidをWebページ上に表示する Part-02
最終更新日:2025-04-15
概要 three.js・three-vrm.jsを使用して、VRoidをWebページ上に表示する方…
記事を閲覧する
three.js・three-vrm.jsを使用して、VRoidをWebページ上に表示する Part-01
最終更新日:2025-04-13
概要 three.js・three-vrm.jsを使用して、VRoidをWebページ上に表示する方…
記事を閲覧する
GIF / APNG(アニメーション付きPNG)ファイル解析ページ
最終更新日:2025-03-31
ファイル読込・操作 以下に調べたいファイルを読み込ませてください。 ファイル情報 カラーパレットを…
記事を閲覧する
gifler.js仕様メモ
最終更新日:2025-03-23
本ページの趣旨 「gifler.js」という、gifアニメーションをcanvasに簡単に表示できる…
記事を閲覧する
【プログラミング】実例で分かるかもしれない再帰処理
最終更新日:2024-12-15
本ページは以下動画の台本を書き起こしたものです 解説の趣旨・方向性 皆さん、こんばんは今回はプログ…
記事を閲覧する
SNSツイート一元化対応(Twitter・Misskey・Mastodon・Bluesky)-公開
最終更新日:2024-12-06
概要 SNSツイートを一元化するためのツールを作成しています(古い記事ですが、こちらのページで紹介…
記事を閲覧する
SNSツイート一元化対応(Twitter・Misskey・Mastodon・Bluesky)-Python
最終更新日:2024-10-13
概要 概要 SNSのツイートを一元化する際の備忘録というかPythonコードの共有です。 それぞれ…
記事を閲覧する
Windows-PowerShellを使用してのフォルダ内のファイル名を連番にリネームする
最終更新日:2024-10-08
以下PowerShellコードを実行することで、フォルダ内のすべてのファイルのファイル名を「0001…
記事を閲覧する
本サイトのタグ一覧
NovelAIR18VRoidWebサイト作成Webツールととモノ。アークナイツアークナイツ-ステージ攻略日記アズールレーンアズールレーン-日記ウマ娘ギャラリーゲームデビラビローグネットスラング系プログラミングホラーポケットタウン怪談気ままな日記情報技術情報技術-WebAPI知的財産権統合戦略白夜極光本サイトについて魔王スライム様がんばる!漫画
人気記事
ポケットタウン_パズル一覧
最終更新日:2025-05-02
スコア:830.3878 pt
グレーのピースの数 (Number of gray pieces):検索グレーピースの数を入力して、…
記事を閲覧する
メイド・オブ・ザ・デッド-攻略お助け情報
最終更新日:2024-05-01
スコア:505.7972 pt
ネタバレ注意! 本ページは『メイド・オブ・ザ・デッド』の情報を記録しているものです。 攻略の参考に…
記事を閲覧する
地獄先生ぬ~べ~で好きな切ないエピソード
最終更新日:2025-07-08
スコア:214.1782 pt
概要 初代というべきか、週刊少年ジャンプで連載されていた地獄先生ぬ~べ~の切ないエピソードの中で好…
記事を閲覧する
ゲーム『イカれた狩場の看板娘』の紹介・レビュー
最終更新日:2025-05-01
スコア:178.5306 pt
記事概要 イカれたゲームを紹介するぜ! イカれた狩場の看板娘! 以上だ! ちなみにそんなイカれてな…
記事を閲覧する
剣と魔法と学園モノ。2G - パーティ編成確認ツール
最終更新日:2024-05-09
スコア:171.9205 pt
ツール概要 ととモノ。2Gのパーティ編成を考える際に使うツールです。 あくまでストーリークリアまで…
記事を閲覧する
黒バス:キセキの世代級の人たちの技一覧
最終更新日:2024-07-21
スコア:112.8617 pt
黒バスのキセキの世代級の人たちの技一覧です 概要 黒バスのキセキの世代級の人たちの技を記載したもの…
記事を閲覧する
アークナイツ-常設商品-理性換算
最終更新日:2024-04-28
スコア:104.5333 pt
概要 "常設商品でお得な商品はどれか"というのを理性に換算して一覧化したものとなります。 絶対的に…
記事を閲覧する
本サイトについて
最終更新日:2025-07-10
スコア:96.0106 pt
本サイトの概要 概要 個人ブログのようなものです。とくにジャンルはありません。 本サイト内の情報に…
記事を閲覧する
最新記事
地獄先生ぬ~べ~新アニメで設定変わったところ(3話まで)
最終更新日:2025-07-13
概要 地獄先生ぬ~べ~の新アニメが2025-07-02(木)よりやっていますが、そこで設定が変わっ…
記事を閲覧する
本サイトについて
最終更新日:2025-07-10
本サイトの概要 概要 個人ブログのようなものです。とくにジャンルはありません。 本サイト内の情報に…
記事を閲覧する
地獄先生ぬ~べ~で好きな切ないエピソード
最終更新日:2025-07-08
概要 初代というべきか、週刊少年ジャンプで連載されていた地獄先生ぬ~べ~の切ないエピソードの中で好…
記事を閲覧する
htmlタグ混在のテキストをhtmlタグとプレーンテキストで分けるJavaScriptコード
最終更新日:2025-06-20
概要 「よくある質問は a href="/" こ span ち /span ら /a です」 とい…
記事を閲覧する
商品サンプル画像
『怪獣8号』第1期総集編
商品ページ
Amazon
収益広告(自動登録)
※Amazonレビュー要確認