(C++) 条件付きループ ステートメント - while


条件付きのループ。 while
ステートメント for ループを学習すると、アクションの繰り返し回数がわかっている場合は、for ループ演算子を使用してプログラムを短縮できると述べました。しかし、繰り返し回数が不明な場合はどうなるでしょうか?これはよく起こります
が。  
10 進数体系から別の数体系への数値の変換を思い出してください。答えがゼロになるまで、数値 (および割り算の結果) をその数値体系の底で割る必要があります。何回シェアするかは不明です。そして、そのようなアルゴリズムを実装するプログラムは非常にたくさんあります。

正確な反復回数がわからない場合、どのようにアルゴリズムを実装すればよいでしょうか?

プログラミングではこのような場合に備えて、条件付きのループ ステートメントがあります。
Python プログラミング言語では、条件付きループ ステートメントは while という単語で始まり、次の構造になります。
while (<condition>) 
{
 ループ本体
}

すでにご存知のとおり、
- condition は、(条件文のように) true または false に評価できる式です。
- ループ本体は繰り返されるコマンドであり、インデントされています。

オペレーターはどのように働いていますか?
1. まず、プログラムは単語 while の後の括弧内の条件を評価します。条件が満たされる (true) 場合、プログラムはループ本体に含まれるステートメントを実行します。
2. ループ本体の実行が完了すると条件チェックに戻り、再度条件チェックを行います。
3. これらのアクション (条件の確認 - ループ本体の実行) は、条件が false になるまで繰り返されます。
4. このステートメントの最初の実行時に条件がすぐに満たされない場合 (false)、プログラムはループ本体を実行しません。

この演算子の動作を分析すると、ループ本体には条件に影響を与える演算子が含まれている必要があることが明らかになるはずです。
たとえば、ループ内で条件で使用される変数の値がインクリメントされる場合があります。

「サイレント カウント」 と呼ぶプログラムの例。
私たちの代わりにプログラムが例えば10まで数えてみましょう
。 プログラムは「Start」というフレーズを出力する必要があります。 「Finish」と「Finish」を押すと、これらのアクションの間に計算中の数値が表示されます。

たとえばこんな感じ
です。 スタート
します。 1 2 3 4 5 6 7 8 9 10
仕上げ

while ループを使用するプログラムは次のようになります。 #include 名前空間 std を使用します。 主要() { int i; cout << "開始\n"; i = 1; while(i <= 10) { cout <<私は << " "; i++; // 条件内の変数の変更に影響を与える演算子 } cout << "\n終了"; }
このプログラムでは、開始点である変数 i = 1 に値を割り当てます。
さらに、i 変数の値が必要な値より大きくない (つまり、以下である) 限り、次のことを行います。
 1.変数 i の値を表示します。
 2.変数 i の値を 1 ずつ増やします。この演算子は括弧内の条件の値に影響します。変数 i はインクリメントされます。これは、ある時点で条件 i <= 10 が false になることを意味します。これは、i が 11 に等しくなったときに発生します。この場合、ループ本体は実行されなくなり、プログラムはループの後の次のステートメントを実行します。 cout << 「\n終了」

タスク
数値を入力し (3,000,000 未満にする)、その桁数を決定する必要があります。
 
解決策のアイデア
数値の最後の桁を順番に切り取るだけです (これは、整数の 10 による除算を使用して数値を 10 倍減らすことで実行できます)。そのたびにカウンターを増やす必要があります。

その結果、番号の桁をすべて切り取った後、カウンターで番号を取得する
ことになります。
このアルゴリズムは次のように定式化できます。
数値が 0 になるまで、数値を 10 ずつ減らし、そのたびにカウンターを 1 ずつ増やします。
  <頭> 数値 (n) カウンター <本体>
プログラムは次のようになります。 #include 名前空間 std を使用します。 主要() { intn、カウント; シン>> n; カウント = 0; ながら (n != 0) { カウント++; n = n / 10; } cout << 「番号-」 << n<< " " を含む<<カウント << "数字";   } このプログラムを暗記する必要があるからです。これに基づいて、桁による数値の計算に関連する他の多くの問題が解決されます。

123 0
12 1
1 2
0 3

タスク

プログラムの入力はデータ ストリームです。ゼロで終わる整数のシーケンス (シーケンスにはゼロは含まれません)。 このシーケンスの要素の合計を見つける必要があります。
 
解決アルゴリズム
<プレ> 合計=0 input x // 最初の数字を入力します while x != 0 // 入力終了符号が条件に設定されます。  nc // つまり、ゼロを入力するまで    sum = sum + x // 元の数値で何かを行うことができます。 // 条件などの数値チェックを追加できます。    input x // 次の数字を入力します kts print sum //結果の出力