(Java) Instrucción de bucle con condición - while


Al estudiar el bucle for, dijimos que si se conoce el número de repeticiones de cualquier acción, entonces puede acortar el programa usando el operador de bucle for. Y qué pasa si no se sabe el número de repeticiones. Y esto sucede muy a menudo.
Por ejemplo:
recordando la traducción de un número de un sistema numérico decimal a cualquier otro, necesitamos dividir el número (y luego el resultado de la división) por la base del sistema numérico hasta que obtengamos cero en la respuesta. No se sabe cuántas veces compartiremos. Y hay bastantes programas que implementan dicho algoritmo. 
¿Cómo se implementa esto?
Para tales casos en programación, existe un operador de bucle con una condición. 
En el lenguaje de programación C, una declaración de ciclo condicional comienza con la palabra while y tiene la siguiente estructura. mientras (<condición>){ cuerpo de bucle } Como ya sabemos:
- una condición es una expresión, cuyo resultado puede ser verdadero o falso (como en una declaración condicional)
- el cuerpo del bucle son los comandos que deben repetirse
- se pueden omitir las llaves si el cuerpo del ciclo consta de un solo operador

Cómo funciona el operador:
1. Primero, el programa evalúa la condición entre paréntesis después de la palabra while. Si la condición se cumple (verdadera), entonces el programa ejecuta las instrucciones contenidas en el cuerpo del ciclo.
2. Al igual que en el ciclo for, si el cuerpo del ciclo contiene solo una declaración, se pueden omitir las llaves que resaltan el cuerpo del ciclo.
3. Una vez completada la ejecución del cuerpo del bucle, el programa vuelve a comprobar la condición y la vuelve a comprobar.
4. Estas acciones (comprobar la condición - ejecutar el cuerpo del bucle) se repiten hasta que la condición se vuelve falsa.
5. Si en la primera ejecución de este operador, la condición no se cumple inmediatamente (falso), entonces el programa nunca ejecutará el cuerpo del ciclo.

Al analizar el trabajo de este operador, debería quedar claro que el cuerpo del ciclo debe contener un operador que afecte la condición.
Por ejemplo, un bucle puede incrementar el valor de una variable utilizada en una condición.

Un ejemplo de un programa que llamaremos "Conteo silencioso"
Hagamos que el programa cuente en lugar de nosotros, por ejemplo, hasta 10.
El programa debe generar la frase "Inicio" y "Terminar", y entre estas acciones se muestran los números que se están calculando.
Así, 
Inicio
1 2 3 4 5 6 7 8 9 10
Terminar
Un programa que usa un ciclo while se vería así. #include<iostream> utilizando el espacio de nombres estándar; principal() { ent yo; cout << "Inicio\n"; yo=1; mientras(i<=10) { cout << yo<<" "; yo++; //Operador que afecta el cambio de variable en la condición } cout << "\nFinalizar"; } En este programa, asignamos un valor a la variable i=1 - el origen
Además, siempre que tengamos el valor de la variable i no mayor (es decir, menor o igual) que el valor que necesitamos,  
 1 - muestra el valor de la variable i 
 2 - aumentar el valor de la variable i en 1 - este operador afecta el valor de la condición entre paréntesis. La variable i se incrementa, es decir, en algún momento la condición i<=10 se volverá falsa. Esto sucederá cuando i sea igual a 11. En este caso, el cuerpo del bucle ya no se ejecutará y el programa ejecutará la siguiente declaración después del bucle, es decir cout << "\nFinalizar";

Intentemos escribir un programa para resolver el siguiente problema:

Debe ingresar un número (que sea menor a 3,000,000 y determine la cantidad de dígitos que contiene).

Idea de solución


Solo necesitamos cortar secuencialmente el último dígito del número (esto se puede hacer reduciendo el número 10 veces, usando la división de enteros por 10), y cada vez que necesitamos aumentar el contador. 
Como resultado, después de cortar todos los números, en el contador obtendremos la cantidad de dígitos en el número.
De otra manera, el algoritmo se puede formular de la siguiente manera:
HASTA QUE EL NUMERO NO SEA CERO DISMINUYELO 10 veces y AUMENTE EL CONTADOR EN 1. El programa se verá así. #include<iostream> utilizando el espacio de nombres estándar; principal() { intn, cuenta; cin>> norte; cuenta = 0; mientras (n != 0) { contar++; n = n/10; } cout << "Número-" <<n<< " contiene " << contar << " dígitos";   } Necesitas saber este programa de memoria, porque. sobre esta base, se resuelven muchos otros problemas relacionados con el cálculo de números por dígitos.

número (n) contador
123 0
12 1
1 2
0 3

Tarea

La entrada del programa es el flujo de datos — una secuencia de números enteros que termina en cero (el cero no está incluido en la secuencia). Necesita encontrar la suma de los elementos de esta secuencia.
 
Algoritmo de resolución
suma=0 entrada x // ingrese el primer número while x != 0 // el signo final de entrada se establece en la condición,  nc // es decir, hasta que ingrese cero    sum = sum + x // puedes hacer algo con el número original. // Puede agregar una verificación de número para alguna condición, etc.    ingrese x // ingrese el siguiente número nudos imprimir suma //resultado de salida