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. Pero, ¿y si no se conoce el número de repeticiones? Y esto sucede muy a menudo.
Por ejemplo, recordemos la conversió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 obtener cero en la respuesta. Se desconoce 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 Pascal, una instrucción de ciclo condicional comienza con la palabra while y tiene la siguiente estructura. mientras que <condición> empezar cuerpo de bucle fin 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
- comienzo y fin se pueden omitir si el cuerpo del bucle consta de un solo operador

Cómo funciona el operador:
1. Primero, el programa evalúa la condición 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 instrucción, se pueden omitir las palabras begin y end 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í. var i: entero; comenzar     writeln('Inicio');     yo := 1;     mientras i <= 10 empiezo         escribir(i, ' ');         yo += 1; //Operador que afecta el cambio de variable en la condición         fin;     escribirln();     writeln('Finalizar'); fin. 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 writeln();
writeln('Finalizar');

Intentemos escribir un programa para resolver el siguiente problema:

Debe ingresar un número (que sea menor a 3,000,000) y determinar la cantidad de dígitos en él.

Idea de solución


Comencemos un contador de dígitos de un número. Inicialmente, el contador es 0. Solo necesitamos eliminar 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 por 1. 
Como resultado, después de cortar todos los dígitos, 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í. var n, cuenta: entero; comenzar     leer(n);     cuenta := 0;     mientras que n <> 0 para comenzar         cuenta += 1;         n := n división 10;     fin;     writeln('Número - ', n, ' contiene ', cuenta, ' dígitos'); fin. 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