¡Libro de enseñanza de conceptos básicos de programación en lenguaje C! ¡Un libro para principiantes!
Al aprender el lenguaje C, siempre debemos recordar que "el amanecer está por delante" y "mirar hacia atrás vale mil dólares. Esta es una forma importante de adquirir conocimientos, es decir, aprender lo siguiente". conocimientos, no olvide regresar y descubrir las preguntas que quedaron atrás y profundizar su comprensión del conocimiento previo. Esto es lo más difícil de hacer para nuestros estudiantes, pero es lo más importante. Por ejemplo, en lenguaje C, la idea más típica es la de programación estructurada. No importa qué tipo de material didáctico, se debe enfatizar este método desde el principio. Es posible que no lo comprenda completamente en este momento, pero cuando aprenda las funciones, regrese y comprendalo cuidadosamente, y no será tan difícil de entender. Aprender el lenguaje C significa pasar por varias iteraciones y acumular el conocimiento de C que debes dominar.
Entonces, ¿cómo aprendemos bien a programar en C?
1. Conozca bien los operadores y las secuencias de operación del lenguaje C.
Esta es la base para aprender bien a programar en C. Las operaciones del lenguaje C son muy flexibles, ricas en funciones y tienen muchos más tipos de operaciones que otros lenguajes de programación. En comparación con otros lenguajes de programación, las expresiones son más concisas, como la autosuma, la autoresta, la operación de coma, la operación de tres ojos, etc., lo que simplifica las expresiones. Sin embargo, los principiantes suelen encontrar esta expresión difícil de entender. La razón principal es que no comprenden completamente los operadores y las secuencias de operación. Cuando varias operaciones diferentes forman una expresión de operación, es decir, cuando hay varios operadores en una expresión, el orden de precedencia y las reglas de combinación de las operaciones son muy importantes. En el aprendizaje no es difícil recordar estas operaciones siempre que las clasifiquemos razonablemente y averigüemos las diferencias entre ellas y las operaciones aprendidas en matemáticas. Después de comprender algunos operadores, los recordará mentalmente y los podrá utilizar fácilmente en el futuro. Algunos operadores pueden abandonarse temporalmente y recordarse cuando los utilice más adelante.
En primer lugar hay que tener claro que los operadores se clasifican según diferentes prioridades. Los operadores en programación C se pueden dividir en 15 prioridades, de mayor a menor, con prioridades que van del 1 al 15. Excepto el segundo nivel, el tercer nivel y el decimocuarto nivel que se combinan de derecha a izquierda, los demás se combinan de izquierda a derecha, lo que determina el orden de operaciones de los operadores del mismo nivel. Usemos algunos ejemplos para ilustrar:
Hay tres operadores en la expresión (1) 5*8/410, que son operadores del mismo nivel, y el orden de las operaciones se combina de izquierda a derecha. . Entonces, primero calcule 5 * 8 = 40, luego divida entre 4, el resultado es 10 y finalmente la operación (resto), por lo que el resultado final de la expresión es 6544.
(2)a = 3; b = 5; c = a* b; d = a * b; table, ejecute primero y luego ejecute *, por lo que después de ejecutar a, el valor de A es 4. Debido a que es una operación previa, el valor de A está involucrado en la operación y la fórmula de cálculo de C es 4*5=20 en lugar de 3*5=15. Para d = a * b, debido a que a es la operación posterior, el valor de 4 está involucrado en la operación, por lo que el valor de d sigue siendo 20. Después de que A participa en la operación, su valor aumenta en 1 y el El valor es 5.
Después de ejecutar este ejemplo, el valor de A es 5, el valor de B es 5, el valor de C es 20 y el valor de D también es 20;
(3)(a = 3 , b = 5, b = a, c = b* 5)
En el ejemplo, "," es una operación de combinación de comas. La fórmula anterior se llama expresión de coma y se combina de izquierda a derecha. . El valor del resultado de la última expresión es el resultado de la expresión de coma, por lo que el resultado de la expresión de coma anterior es 40, el valor de A es 3, el valor de B es 8 y el valor de C es 40.
(4)a = 5; b = 6; c = agtb? A: B;
¿Un gtb en el ejemplo? A: b es una operación de tres ojos, que se utiliza para realizar operaciones relacionales A> en la parte B, si el resultado es verdadero, el valor de A se toma después del signo de interrogación; de lo contrario, el valor de B se toma después del signo de interrogación. dos puntos, por lo que el valor de C debería ser 6 . Esta operación se puede utilizar para reemplazar la aplicación simple de declaraciones if...else....
2. Aprenda bien las cuatro estructuras de programas del lenguaje C
(1) Estructura de secuencia
La programación de la estructura de secuencia es la más simple, siempre que sepa siga la resolución del problema Escriba las declaraciones correspondientes en el orden y su orden de ejecución es de arriba hacia abajo.
Por ejemplo; A = 3, b = 5, ahora intercambiando los valores de A y b, este problema es como intercambiar dos vasos de agua, claro que se necesita una tercera taza. Si la tercera copa es C, entonces el programa correcto es: C = a; a = b = c; Si se cambia el orden, se escribe como: a = b;; c = a; b = c; entonces el resultado de la ejecución es a = b = c = 5, lo que es más probable que no logre el propósito esperado. tales errores. Las estructuras de secuencia se pueden utilizar de forma independiente para formar un programa simple y completo. Un programa común para la trilogía de entrada, cálculo y salida es la estructura de secuencia. Por ejemplo, la secuencia de instrucciones del programa consiste en ingresar el radio r del círculo, calcular s = 3,14159*r*r y generar el área s del círculo. Pero en la mayoría de los casos, la estructura de secuencia es parte del programa, junto con otras estructuras, forma un programa complejo, como declaraciones compuestas en estructuras de rama y cuerpos de bucle en estructuras de bucle.
(2) Estructura de ramas
Aunque los programas con estructuras de secuencia pueden resolver problemas de cálculo y salida, no se pueden juzgar antes de la selección. Para cuestiones que requieren juicio antes de la selección, utilice una estructura de ramificación. La ejecución de la estructura de rama selecciona la ruta de ejecución de acuerdo con ciertas condiciones, en lugar de seguir estrictamente el orden físico en que aparecen las declaraciones. La clave del método de programación de estructura de bifurcación es construir condiciones de bifurcación apropiadas, analizar el flujo del programa y seleccionar declaraciones de bifurcación apropiadas de acuerdo con los diferentes flujos del programa. La estructura de rama es adecuada para cálculos de juicios condicionales como comparaciones lógicas o relacionales. Al diseñar un programa de este tipo, a menudo es necesario dibujar primero su diagrama de flujo del programa y luego escribir el programa fuente de acuerdo con el flujo del programa para separar el análisis del diseño del programa del lenguaje para que el problema sea simple y fácil de entender. Un diagrama de flujo de un programa es un diagrama de flujo de ejecución de un programa elaborado en base al análisis de resolución de problemas.
No se deje confundir por el anidamiento de ramas cuando aprenda las estructuras de las ramas, siempre que el diagrama de flujo esté dibujado correctamente y las funciones que debe realizar cada rama sean claras, la estructura anidada no es difícil. El anidamiento es solo una rama que contiene una declaración de rama y no es un conocimiento nuevo. Siempre que comprenda claramente las ramas duales, el anidamiento de ramas no es difícil. Permítanme presentarles algunas estructuras básicas de sucursales.
①Si (condición)
{
Rama
}
Las ramas en esta estructura de rama pueden Es una declaración, en cuyo caso "" se puede omitir, o pueden ser varias declaraciones, es decir, una declaración compuesta. Tiene dos caminos bifurcados para elegir. Una es ejecutar la rama cuando la condición es verdadera; de lo contrario, omita la rama y no la ejecute. Por ejemplo, al calcular el valor absoluto de x, de acuerdo con la definición de valor absoluto, sabemos que cuando x> = 0, su valor absoluto permanece sin cambios, y Otros
Esta es una estructura de rama típica. Si la condición es verdadera, se ejecuta la rama 1; de lo contrario, se ejecuta la rama 2, la rama 1 y la rama 2. La rama 2 puede estar compuesta por 1 o varias declaraciones.
Por ejemplo, encuentre la raíz de ax ^ 2 bx c = 0.
Análisis: Porque cuando B 2-4ac >;=0, la ecuación tiene dos raíces reales, en caso contrario (b 2-4ac
d = b* b-4* a* c;
if(d gt;=0)
{ x 1 =(-b sqrt(d))/2a;
x 1 = ( -b-sqrt(d))/2a;
printf("x1=8.4f, x2=8.4f\n ", x1, x2);
} p >
Otro
{ r =-b/(2 * a);
I = sqrt(-d)/(2 * a);
printf(" x 1 = 8.4f 8.4 fi \ n " r, I
printf("x2=8.4f-8.4fi\n" r, I)
< p); >}③ Declaración de rama anidada: el formato de la declaración es:
If (condición 1
Else if (condición 2)
<); p>Si no (condición 3)......
Si no (condición n)
Otros
Anidados Las declaraciones de ramas pueden resolver el problema de múltiples entradas y salidas, pero después de tres o más anidamientos, la estructura de la oración se vuelve muy complicada, lo que es extremadamente inconveniente para la lectura y comprensión del programa. Se recomienda anidar dentro del triple. triple, puede usar la siguiente declaración.
④ declaración de cambio: esta declaración también es una declaración de selección de múltiples ramas. El bloque que se ejecuta depende de la configuración del interruptor, es decir, la ruta donde se encuentra el valor. la expresión coincide con la expresión constante. Es diferente de la declaración if...else. Todas sus ramas son paralelas. Cuando se ejecuta el programa, la primera rama comienza a buscar y, si hay una coincidencia, se ejecutan los bloques siguientes. y luego los bloques de la segunda rama y la tercera rama se ejecutan hasta que no se encuentre ninguna coincidencia. Compruebe si la siguiente rama coincide. Al aplicar esta declaración, preste especial atención a la configuración razonable de la condición de cambio y la aplicación razonable de la interrupción. declaración
(3) Estructura periódica:
Estructura de bucle. Puede reducir la carga de trabajo de la escritura repetida en el programa fuente y puede usarse para describir el problema de la ejecución repetida de un. algoritmo Esta es la estructura del programa que mejor utiliza las fortalezas de las computadoras en la programación. El lenguaje C proporciona cuatro bucles, a saber, bucles goto y bucles while, y se pueden usar cuatro bucles para resolver el mismo. Problema y generalmente se pueden reemplazar entre sí, pero generalmente no se recomienda usar bucles goto porque cambiar a la fuerza el orden del programa a menudo hará que el programa se ejecute de manera impredecible. Error En el aprendizaje, aprendemos principalmente mientras, hacer... while y for. El objetivo de aprender las tres estructuras de bucle de uso común es encontrar sus similitudes y diferencias para que puedan usarse en diferentes situaciones. Esto requiere una comprensión clara del formato y la secuencia de ejecución de los tres bucles, y una comprensión profunda del diagrama de flujo de cada bucle, lo que le ayudará a comprender cómo reemplazarlos. Por ejemplo, tome el bucle while como ejemplo y reescriba un programa usando declaraciones for para comprender mejor su funcionalidad. Preste especial atención a las declaraciones que tienden a terminar en el cuerpo del bucle (es decir, cambios en los valores de las variables del bucle); de lo contrario, puede convertirse en un bucle infinito, lo cual es un error común entre los principiantes.
Después de aprender estos tres bucles, es necesario aclarar sus similitudes y diferencias: cuando se utilizan los bucles while y do... while, la operación de inicialización de las variables del bucle debe realizarse antes del cuerpo del bucle, mientras que for El bucle generalmente se realiza en la instrucción 1; Los bucles While y for juzgan las expresiones primero y luego ejecutan el cuerpo del bucle, mientras que los bucles while do... while juzgan las expresiones primero, lo que significa que el cuerpo del bucle de do... while se ejecuta en al menos una vez, mientras que los bucles while y for no pueden ejecutarse una vez.
Además, cabe señalar que los tres tipos de bucles pueden utilizar la instrucción break para salir del bucle y la instrucción continue para finalizar el bucle. Sin embargo, el bucle formado por la instrucción goto y if no puede ser controlado por break. y continuar declaraciones.
La estructura de secuencia, la estructura de rama y la estructura de bucle no están aisladas entre sí. Puede haber ramas y estructuras de secuencia en bucles, y bucles y estructuras de secuencia en ramas. De hecho, independientemente de la construcción, podemos considerarlas declaraciones en el sentido más amplio. En el proceso de programación real, estas tres estructuras a menudo se combinan entre sí para implementar varios algoritmos y diseñar los programas correspondientes. Pero la programación es un gran problema. Los programas escritos suelen ser muy largos y repetitivos, lo que resulta en mala legibilidad y dificultad de comprensión. La forma de resolver este problema es diseñar el programa C en una estructura modular.
(4) Estructura modular del programa
La estructura modular del programa del lenguaje C se realiza a través de funciones, es decir, el programa C complejo se divide en varios módulos y cada módulo está escrito. como una función C, y luego escriba un programa C para un problema grande llamando funciones desde la función principal y llamando funciones desde la función, por lo que a menudo se dice que programa C = subfunción de la función principal. Por lo tanto, se debe prestar especial atención a la comprensión y aplicación de las definiciones de funciones, llamadas y valores de retorno, y se deben consolidar mediante la depuración informática.
3. Domina algunos algoritmos simples.
De hecho, una gran parte del trabajo de programación consiste en analizar problemas, encontrar soluciones a los problemas y luego escribir código en el lenguaje de programación correspondiente. Esto requiere dominar los algoritmos. Según nuestro programa de programación en C, sólo necesitas dominar algunos algoritmos simples. Después de dominar estos algoritmos básicos, es fácil completar el análisis del problema. Por ejemplo, el intercambio de dos números, la comparación de tres números, la clasificación por selección y la clasificación por burbujas requieren que aclaremos el significado intrínseco de estos algoritmos. Entre ellos, la clasificación por selección y la clasificación por burbujas son un poco difíciles, pero siempre que lo hagamos. Comprender los detalles específicos de clasificación y proceso, no es difícil entender el código. Si utiliza el método de selección para ordenar 10 números enteros diferentes (de pequeño a grande), la idea de clasificación del método de selección es: hay 10 elementos a [1] ~ a [10], a [1] y A [ 2]~A [65438] Si uno de a[2]~a[10] es menor que a[1], el máximo es en la segunda ronda, a[2] se compara con a[3]~a[10 ], y quedan 9. El número más pequeño a[i] se intercambia con a[2], que es el segundo número más pequeño entre los 10 números almacenados en a[2]. Por analogía, * * * realiza 9 rondas de comparación y de [1] a [10] se han almacenado en orden descendente. Es decir, encuentre el número restante más pequeño en cada ronda. El código es el siguiente:
for(I = 1; I lt=9; i)
for(j = I. 1; j lt=10; j )
si(a[I] gt; a[j]
{ temp = a[I];
a[ I]= a[j];
a[j]= temp;
}
Conclusión: Cuando comprendemos los aspectos anteriores, siempre y cuando Como los estudiantes pueden superar su miedo a las dificultades y su disgusto por aprender, prestar atención a las conferencias en clase y hacer ejercicios y depurar en la computadora. De hecho, el lenguaje C no es difícil de aprender.