1月27日 基本情報技術者『実戦問題』のアルゴリズムの章でこうしろうが,「うーん,わからん」となったのは選択ソートのフローチャート(流れ図)に関する問題だった。
問題.選択ソートを使って,配列Tに格納されたn個のデータを昇順に整列する次の流れ図の空欄aに入れるべき適切な条件はどれか。
「フローチャート」懐かしい響きである。筆者,20代の前半まではCOBOL言語でホストコンピュータやオフコン(オフィス・コンピュータの略語であるが英語ではない。そもそもオフィス・コンピュータという概念が日本独自のものである。CPUは80X86系のものが多かったので,ハード的にはPCに近かったのだろう。その割に高価だったが…)のプログラムや,プログラム仕様書にプラスチック製のテンプレートでバッチ処理のフローばっかり書いていた。だから,フローチャートはいたって得意なのだ。エヘン!
なんて,古臭い知識を自慢していないで,若い読者のためにバッチ処理についても説明しておこう。ブラウザを開いて,商品の注文サイトで商品を選び数量を入力,注文ボタンをクリックして完了。っていうのがオンライン処理。その後,注文を受けたコンピュータが一日の注文データをまとめて集計したり,売上伝票を印刷したりするのがバッチ処理。人間の操作による介入がないので,流れるようにフローチャートで処理を定義できるのである。いささかかカビ臭い感じもするが,知っておいた方が良い表現方法である。
「こうしろう,それ,どんだけ頭の中で考えても,わからんちゃ」(うーん。今日もかなり富山弁)「紙に配列を書いてみて,ループ1ごとに配列の中の値がどう置き換わるか書いていけば,すぐわかるよ」
選択ソートでは下図のように値を並べ替えていく。
先に言っちゃうと,答えはエのT(p)>T(j + 1)である。
ループ1は,例えばC言語で書くと for(i = 1; i < n - 1; i++ )
と,ループ2はfor(j = i; j < n - 1; j++) となる。順を追って説明していこう。まず,ループ1の始端でiが1になる。i → pでpも1になる。次にループ2の始端でj = i,つまりjも1になる。問題のaの箇所でT(p)>T(j + 1) = T(1)>T(1 + 1),つまり7が2より大きいかを判断している。Yesなので,j + 1(= 2)をpに入れる。
ループ2はj < n - 1の間繰り返される。2回めのループ2ではT(2)より小さい値がないかT(3)以降と比較していく。あった場合は,その添え字をpに入れていく。比較は配列の終端まで繰り返される。この例では,T(2) = 2が一番小さい値なので,ループ2の終了時にT(p) = T(2)とT(i) = T(1)を入れ替える。結果T(1)には配列中で一番小さい値2が入り,T(2)にはT(1)に入っていた7が入る。ループ1の始端に戻りiに1を加算して,次に小さい値をT(2)に入れる処理が繰り返される。
ループ1終了時点では,昇順に値が並んだ配列Tができあがるのである。
第79話 ソート処理のフローチャートを考える
あなたにお薦め
今日のピックアップ
-
不要な製品の購入を強いられる、ブロードコムのVMware買収で悪影響
-
米GitHubが「Workspace」を開始、ソフト開発の課題をAIが自動解決
-
Core Ultra搭載の「dynabook R9」、35時間駆動の実力
-
パスワード管理や不正サイト対策はEdgeもChromeも充実、複数機器の同期は選べる
-
コメント関連が使いやすくなった新Acrobat Reader、「クイックツールバー」に集約
-
M3搭載「MacBook Air」とM2搭載モデルを比較、外付けディスプレー2台接続も試す
-
有名人になりすまして投資広告を掲載、SNSで接触してみた結果
-
NECが受注したe-Govのガバクラ移行が大幅遅延、構築手法の途中変更が影響か
-
IIJ公式サイトのPVがある日突然13倍に、バズったわけでも炎上したわけでもない裏側
-
アリババのデジタル人材育成プログラム、世界の起業家や若者4千人以上にノウハウ提供
-
縦長のWebページ全体を画像で保存、メニューから選べるEdgeがChromeより便利
-
「四重苦」で伸び悩む日本市場、なぜ海外スマホメーカーが開拓に本腰を入れるのか
注目記事
おすすめのセミナー
-
「仮説立案」実践講座
例えば「必要な人材育成ができていない」といった課題に、あなたならどう取り組みますか? このセミナ...
-
CIO養成講座 【第35期】
業種を問わず活用できる内容、また、幅広い年代・様々なキャリアを持つ男女ビジネスパーソンが参加し、...
-
改革リーダーのコミュニケーション術
プロジェクトを成功に導くために改革リーダーが持つべき3つのコミュニケーションスキル—「伝える」「...
-
パワポ資料が見違える「ビジネス図解」4つのセオリー
インフォグラフィックスとは、形のない情報やデータなど伝えたいことを分かりやすい形で表現する技法で...
-
間違いだらけの設計レビュー
本セミナーでは、現場で多く見られる間違ったレビューの典型例を示し、そうならないための現場の改善策...
-
オンライン版「なぜなぜ分析」演習付きセミナー実践編
このセミナーでは「抜け・漏れ」と「論理的飛躍」の無い再発防止策を推進できる現場に必須の人材を育成...
-
問題解決のためのデータ分析活用入門
例えば「必要な人材育成ができていない」といった課題に、あなたならどう取り組みますか? このセミナ...
-
業務改革プロジェクトリーダー養成講座【第16期】
3日間の集中講義とワークショップで、事務改善と業務改革に必要な知識と手法が実践で即使えるノウハウ...
注目のイベント
-
日経クロステックNEXT 関西 2024
2024年5月16日(木)~5月17日(金)
-
日経ビジネスCEOカウンシル
2024年5月16日(木)17:00~19:50
-
WEURO DIVERSITY & INCLUSION FORUM
2024年5月17日(金)13:00~17:30(予定)
-
VUCA時代に勝ち残る戦略的サプライチェーン構築に向けて
2024年 5月 24 日(金) 10:00~16:20
-
人手不足を乗り越える 日本の産業界成長のシナリオ2024
2024年5月30日(木)10:20~17:45
-
人的資本経営版:日経ビジネスLIVE 2024 Spring
2024年6月3日(月)~6月5日(水)
-
DX Insight 2024 Summer
2024年6月4日(火)、5日(水)
-
付加価値ある意匠デザインを実現するものづくり技術2024
2024年6月7日(金)10:30 ~ 17:00
-
WOMAN EXPO 2024
2024年6月8日(土)10:00~17:30
-
デジタル立国ジャパン2024
2024年6月10日(月)、11日(火)
おすすめの書籍
-
ソフトバンク もう一つの顔 成長をけん引する課題解決のプロ集団
ソフトバンクにはモバイルキャリア事業以外のもう一つの顔が存在する。本書ではキーパーソンへのインタ...
-
対立・抵抗を解消し合意に導く 改革リーダーのコミュニケーション術
本書は、改革リーダーに必須のコミュニケーション術を3つのスキルの観点からまとめ上げたものです。今...
-
もっと絞れる AWSコスト超削減術
本書ではコスト課題を解決するため、AWSコストを最適化し、テクニックによって削減する具体策を紹介...
-
優秀な人材が求める3つのこと 退職を前提とした組織運営と人材マネジメント
「学生に人気のコンサルであっても、大手企業であっても、せっかく獲得した人材が数年で辞めてしまう...
-
Web3の未解決問題
ブロックチェーン技術を主軸とするWeb3の技術について、現在の社会制度との摩擦と、その先にある新...
-
ロボット未来予測2033
ロボットの用途・市場はどう拡大していくのか。AI実装でロボットはどこまで進化するのか。技術の進展...