domingo, 24 de enero de 2010

***

DIAGRAMAS DE FLUJO

Problema. El problema es un asunto del que se espera una solución, es el inicio de la investigación, ya que la cadena comienza con Problema ---> Investigación ---> Solución.

El problema responde al porqué y se refiere al objeto que provoca una necesidad en algún sujeto, el cual desarrollará una actividad para transformar la situación mencionada.

Para que exista el problema, la situación debe generar una necesidad en el sujeto, así como un problema científico es la consecuencia del límite de conocimientos actuales que genera la insatisfacción de las necesidades del sujeto.

El problema surge del resultado del diagnóstico de la situación del objeto en que se manifiesta un conjunto de fenómenos, hechos y procesos no explicables.

Conceptos de Programación.

Resolución de Problemas por computadora. El proceso de resolución de problemas conduce a la escritura de un programa y a su ejecución en la misma, aunque el proceso de diseño del programa es esencialmente un proceso creativo, y se pueden considerar una serie de fases o pasos comunes que generalmente deben seguir todos los programadores.

Método Científico. El término método es el camino por el que se llega a un resultado; el método científico es un proceso que se sigue en las ciencias para encontrar la verdad y enseñarla. La ciencia recurre a la postulación y prueba de hipótesis para buscar el conocimiento que explica los fenómenos del universo, predice sus relaciones mutuas y establece leyes generales.

Conceptos Generales.

1. Datos: Es una parte que describe un objeto específico.

2. Información: Conjunto de datos que generan un conocimiento en general.

3. Informática: Ciencia que se encarga del tratamiento sistemático y automatizado de la información mediante la creación de métodos y técnicas para el desarrollo de nuevos dispositivos.

4. Computación. Conjunto de disciplinas y técnicas desarrolladas para el tratamiento informático de la información mediante el uso de computadoras.

5. Instrucción. Orden que se da para ejecutar una acción, sinónimo de comando que realiza una acción en lenguaje de programación que puede entender y ejecutar una computadora.

6. Programa. Conjunto de instrucciones que indican a una computadora cómo realizar una operación.

7. Programación. Es la elaboración de programas.

8. Constantes. Es una variable cuyo valor puede determinar el compilador durante la compilación. Para que esto sea posible, se ha de cumplir que el valor de una constante no pueda cambiar durante la ejecución, por lo que el compilador informará con un error de todo intento de modificar el valor inicial de una constante.

Fases de solución de un problema con computadora.

1. Análisis del problema
2. Diseño de algoritmo
3. Codificación
4. Complilación y Ejecución
5. Verificación
6. Depuración
7. Documentación

Las dos primeras fases conducen a un diseño detallado descrito como algoritmo. Durante la tercera etapa, se implementa el algoritmo en un código escrito en un lenguaje de programación. En la etapa cuatro el programa se traduce, y en las siguientes dos etapas, el programa busca errores, haciendo por último la documentación.

Algoritmos

1.- ¿Qué es un algoritmo?
Un algoritmo es un conjunto finito de instrucciones o pasos que sirven para ejecutar una tarea o resolver un problema.

2.- Da tres ejemplos cotidianos de algoritmo
En la vida cotidiana empleamos algoritmos en multitud de ocasiones para resolver diversos problemas, como por ejemplo para poner una lavadora (conjunto de instrucciones pegadas en la tapa de la máquina), para tocar música (partituras), para construir un aeroplano a escala (expresados en las instrucciones), para hacer trucos de magia (pasos para hacer el truco) o, incluso, para hacer recetas de cocina (pasos de la receta).

3.- Características de un algoritmo
Las características fundamentales que debe cumplir todo algoritmo son:
·Un algoritmo debe ser preciso e indicar el orden de realización de cada paso.
·Un algoritmo debe estar definido. Si se sigue un algoritmo dos veces, se debe obtener el mismo resultado cada vez.
·Un algoritmo debe ser finito. Si se sigue un algoritmo se debe terminar en algún momento; o sea, debe tener un numero finito de pasos.

La definición de un algoritmo debe definir tres partes: Entrada, Proceso y Salida. En el algoritmo de receta de cocina citado anteriormente se tendrá:

Entrada: ingrediente y utensilios empleados.
Proceso: elaboración de la receta en la cocina.
Salida: terminación del plato (por ejemplo, cordero).

4.- Símbolos que se ocupan en un diagrama de flujo.



5.- Reglas básicas para realizar un diagrama de flujo.
  • El diagrama puede desarrollarse en cualquier dirección, sin embargo es aconsejable que el desarrollo se realice en lo posible de arriba hacia abajo y de izquierda a derecha.

  • Debe procurarse que el símbolo de inicio se encuentre en la parte superior o superior-izquierda del diagrama.

  • El final se debe procurar que quede en la parte inferior o inferior-derecha. Si esto no es posible, debe separarse ligeramente del cuerpo del diagrama a fin de que sea fácilmente identificado.

  • Se pueden utilizar palabras para especificar la acción dentro del símbolo como es el caso de “Introducir A y B”, aunque esto es innecesario ya que con poner simplemente “A, B” se sobreentiende. Es el mismo caso de poner “Comparar si A>B” o simplemente “A > B”.

  • Es válido hacer que dos flechas apunten a un símbolo, aunque es más estético hacer que la segunda flecha apunte a la primera que si está apuntando al símbolo, tal como se hace en el caso del “FIN”.

Variables Con Funciones Específicas

Dentro de los algoritmos, se encuentran los contadores y acumuladores de valores o interruptores. Estas son variables que auxilian el diseño de un algoritmo.

Contadores

Son variables que se utilizan para llevar un conteo dentro de un programa, el cual inicia generalmente desde cero. Las operaciones necesarias para un contador son:

1.- Asignar un valor de inicio que tomará este contador
2.- Incrementar de uno en uno o tomar un valor de incremento determinado

Acumuladores

Son variables que almacenan la suma o el producto de los elementos sucesivos. Esta operación siempre se debe inicializar.

C#

¿Qué es programar?

Programar es hacer que la computadora siga una serie de instrucciones bien detalladas. Usando un lenguaje de programación indicamos a la computadora qué tiene que suceder en cada momento, y cómo debe de reaccionar ante la interacción con el usuario.

Se conoce como programación de computadoras a la implementación de un algoritmo en un determinado lenguaje de programación, conformando un programa.

Programa

Concepto desarrollado por Von Newmann en 1946. Se define como la unión de una secuencia de instrucciones que una computadora puede interpretar y ejecutar. Y una o varias estructuras de datos que almacenan la información independiente de las estructuras que dicha secuencia de instrucciones maneja.

Según Niklaus Wirth, un programa está formado por algoritmos y estructuras de datos.


Lenguaje de Programación

Es la traducción del lenguaje "hombre" al lenguaje "máquina", el cual tiene un número limitado de datos y palabras.
Está constituido por un conjunto de reglas:

1. Sintácticas. Especifican la formación de instrucciones válidas
2. Semánticas. Especifican el significado de estas instrucciones

Elementos Léxicos de un Programa

1. Comentarios. Anotaciones para documentar el programa. Existen dos formas de colocar comentarios:

// Para un renglón ÚNICAMENTE
/* Para más de un renglón */

2. Palabras Reservadas. Palabras que tienen un determinado significado para el compilador

3. Identificadores. Nombres que los programadores dan a los diferentes elementos de un programa. Deben de tener las siguientes características:

1) Letras, Dígitos o Caracteres
2) Diferentes a las palabras reservadas
3) No comenzar con dígitos
4) Sensible a mayúsculas y minúsculas
5) Debe contener nombres significativos

4. Operadores y Punteros. Los operadores identifican las operaciones y los punteros agrupan o separan. { }

5. Literales. Valores constantes escritos directamente en el programa

6. Directivas del pre-procesador. Instrucciones al compilador. Comienza con signo de #


SENTENCIAS Y BLOQUES

La sentencia es la representación de una acción o secuencia de acciones ejecutables (operaciones) o no ejecutables (declaraciones).

Los bloques son grupos de sentencias delimitadas por llaves ({ })


MÉTODO MAIN

Es el punto de entrada al programa, y la ejecución siempre inicia en el método Main.
El método Main debe ser:

Declarado Static en una clase u estructura, debe regresar "void" o "int". Debe ser escrito Main, y puede no tener parámetros y recibir un arreglo de Strings

Antecedentes de C# (1970-Actualidad)

*Principio de la década de los 70s ----> El Prolog (o PROLOG), proveniente del francés PROgrammation en LOGique, es un lenguaje de programación lógico e interpretado, bastante conocido en el medio de investigación en Inteligencia Artificial.

*Año 1970 ----> Pascal es un lenguaje de programación desarrollado por el profesor suizo Niklaus Wirth a finales de los años 60. Su objetivo era crear un lenguaje que facilitara el aprendizaje de la programación a sus alumnos. Sin embargo con el tiempo su utilización excedió el ámbito académico para convertirse en una herramienta para la creación de aplicaciones de todo tipo.

*Año 1972 ----> C es un lenguaje de programación creado en 1972 por Dennis M. Ritchie en los Laboratorios Bell como evolución del anterior es decir el lenguaje B, a su vez basado en BCPL.

*Año 1973 ----> En 1973, el lenguaje C se había vuelto tan potente que la mayor parte del kernel Unix, originalmente escrito en el lenguaje ensamblador PDP-11/20, fue reescrita en C. Éste fue uno de los primeros núcleos de sistema operativo implementados en un lenguaje distinto al ensamblador.

*Mediados de la década de los 70s ----> Scheme es un lenguaje de programación. Es un lenguaje funcional (si bien impuro, ya que, por ejemplo, sus estructuras de datos no son inmutables) y un dialecto de Lisp. Fue desarrollado por Guy L. Steele y Gerald Jay Sussman en la década de los setenta e introducido en el mundo académico a través de una serie de artículos conocidos como los Lambda Papers de Sussman y Steele.

*Año 1978 ----> En 1978, Ritchie y Brian Kernighan publicaron la primera edición de El lenguaje de programación C, también conocido como La biblia de C. Este libro fue durante años la especificación informal del lenguaje. El lenguaje descrito en este libro recibe habitualmente el nombre de "el C de Kernighan y Ritchie" o simplemente "K&R C"

*Año 1979 ----> ADA Ada es un lenguaje de programación orientado a objetos y fuertemente tipado de forma estática que fue diseñado por Jean Ichbiah de CII Honeywell Bull por encargo del Departamento de Defensa de los Estados Unidos. Es un lenguaje multipropósito, orientado a objetos y concurrente, pudiendo llegar desde la facilidad de Pascal hasta la flexibilidad de C++

*Finales de la década de los 70s ----> A finales de la década de 1970, C empezó a sustituir a BASIC como lenguaje de programación de microcomputadores predominante.

*Década de los 80s ----> Bjarne Stroustrup empezó a trabajar con algunos compañeros de Bell Labs para añadir funcionalidades de programación orientada a objetos a C. El lenguaje que crearon, llamado C++, es hoy en día el lenguaje de programación de aplicaciones más común en el sistema operativo Microsoft Windows

*Año 1983 ----> C++ es un lenguaje de programación diseñado a mediados de los años 1980 por Bjarne Stroustrup. La intención de su creación fue el extender al exitoso lenguaje de programación C con mecanismos que permitan la manipulación de objetos. En ese sentido, desde el punto de vista de los lenguajes orientados a objetos, el C++ es un lenguaje híbrido.

*Año 1984 ----> MATLAB (abreviatura de MATrix LABoratory, "laboratorio de matrices") es un software matemático que ofrece un entorno de desarrollo integrado (IDE) con un lenguaje de programación propio (lenguaje M). Está disponible para las plataformas Unix, Windows y Apple Mac OS X.Entre sus prestaciones básicas se hallan: la manipulación de matrices, la representación de datos y funciones, la implementación de algoritmos, la creación de interfaces de usuario (GUI) y la comunicación con programas en otros lenguajes y con otros dispositivos hardware.

*Año 1987 ----> Perl es un lenguaje de programación diseñado por Larry Wall en 1987. Perl toma características del lenguaje C, del lenguaje interpretado shell (sh), AWK, sed, Lisp y, en un grado inferior, de muchos otros lenguajes de programación. Estructuralmente, Perl está basado en un estilo de bloques como los del C o AWK, y fue ampliamente adoptado por su destreza en el procesado de texto y no tener ninguna de las limitaciones de los otros lenguajes de script.

*Año 1989 ----> Tras un proceso largo y arduo, se completó el estándar en 1989 y se ratificó como el "Lenguaje de Programación C" ANSI X3.159-1989. Esta versión del lenguaje se conoce a menudo como ANSI C, o a veces como C89 (para distinguirla de C99).

*Año 1990 ----> En 1990, el estándar ANSI (con algunas modificaciones menores) fue adoptado por la Organización Internacional para la Estandarización (ISO) en el estándar ISO/IEC 9899:1990. Esta versión se conoce a veces como C90. No obstante, "C89" y "C90" se refieren en esencia al mismo lenguaje.

*Año 1991 ----> Java es un lenguaje de programación orientado a objetos desarrollado por Sun Microsystems a principios de los años 90. El lenguaje en sí mismo toma mucha de su sintaxis de C y C++, pero tiene un modelo de objetos más simple y elimina herramientas de bajo nivel, que suelen inducir a muchos errores, como la manipulación directa de punteros o memoria.

*Año 1995 ----> PHP es un lenguaje de programación interpretado, diseñado originalmente para la creación de páginas web dinámicas. Es usado principalmente en interpretación del lado del servidor (server-side scripting) pero actualmente puede ser utilizado desde una interfaz de línea de comandos o en la creación de otros tipos de programas incluyendo aplicaciones con interfaz gráfica usando las bibliotecas Qt oGTK+.

*Año 1999 ----> C# (pronunciado si sharp en inglés) es un lenguaje de programación orientado a objetosdesarrollado y estandarizado por Microsoft como parte de su plataforma .NET, que después fue aprobado como un estándar por la ECMA e ISO. En enero de 1999, Anders Hejlsberg formó un equipo con la misión de desarrollar un nuevo lenguaje de programación llamado Cool (C Orientado a Objetos). Este nombre tuvo que ser cambiado debido a problemas de marca pasando a llamarse C♯ aunque habitualmente se escribe C#.1 La biblioteca de clases de la plataforma .NET fue migrada entonces al nuevo lenguaje.

*Año 2000 ----> Tras el proceso de estandarización de ANSI, la especificación del lenguaje C permaneció relativamente estable durante algún tiempo, mientras queC++ siguió evolucionando. Sin embargo, el estándar continuó bajo revisión a finales de la década de 1990, lo que llevó a la publicación del estándar ISO 9899:1999 en 1999. Este estándar se denomina habitualmente "C99". Se adoptó como estándar ANSI en marzo de 2000.

*Año 2001 ----> C♯, como parte de la plataforma .NET, está normalizado por ECMA desde diciembre de 2001.

*Año 2005 ----> El 7 de noviembre de 2005 salió la versión 2.0 del lenguaje que incluía mejoras tales como tipos genéricos, métodos anónimos, iteradores, tipos parciales y tipos anulables.

*Año 2007 ----> El 19 de noviembre de 2007 salió la versión 3.0 de C# destacando entre las mejoras los tipos implícitos, tipos anónimos y LINQ (Language Integrated Query -consulta integrada en el lenguaje).

Espacio De Nombres

Es una clasificación especial utilizada para agrupar un conjunto de clases y estructuras relacionadas, así como aislar ese grupo de nombres en conjuntos de datos. No se deben tener dos clases con el mismo nombre en un espacio de nombres, y pueden ser predefinidos o definidos por el usuario.

Sintaxis:

namespace NombreEspacio
{
// aquí van las clases del espacio de nombres
}

Clase. Unidad básica en la programación orientada a objetos. Todo programa en C# se organiza en clases que encapsulan datos y comportamientos.

Una clase se construye con la palabra seguido del nombre de la clase y el símbolo de inicio y final de un bloque para delimitar la codificación de sus miembros.

class NombreClase
{
// Aquí se codifican los miembros de la clase
}

Métodos para escribir datos

1. Write --> Escribe sin añadir el caracter de fin de línea a la cadena
2. WriteLine --> Sí añade el caracter del fin de línea a la cadena, de modo que lo siguiente que se escriba se colocará en la siguiente línea.

Ejemplo:
Console.Write ("Hola");
Console.WriteLine ("Pepe");
Console.Write ("Cómo Estás, ");
Console.WriteLine ("¿bien?");

Ofrecería este resultado en la consola:

HolaPepe
Cómo estás, ¿bien?


Métodos para leer datos

variable = Console.Read(); //Lee un caracter
cadena = Console.ReadLine (); //Lee una cadena


Variables y Constantes

Variable --> Condición con nombre en memoria donde se almacena un valor de un cierto tipo de dato y puede ser modificado. Las variables pueden almacenar cadenas, números y estructuras. Tiene un nombre (un identificador) que describe su propósito.

Constante --> Variable cuyo valor no puede ser modificado


Tipos de Números

Números Enteros --> Probablemente el tipo de dato más familiar identificado con la palabra reservada int

Números Reales --> Números decimales o números muy grandes

Caracteres --> Cualquier elemento de un conjunto de caracteres o alfabeto (letras, dígitos, símbolos y signos de puntuación)

Programación Orientada a Objetos (POO)

La programación orientada a objetos es un paradigma de programación que usa objetos y sus interacciones, para diseñar aplicaciones y programas de ordenador. Está basado en varias técnicas, incluyendo herencia, abstraccion, polimorfismo y encapsulamiento. En la actualidad, existe variedad de lenguajes de programación que soportan la orientación a objetos. La programación orientada a objetos tomó posición como el estilo de programación dominante a mediados de los años ochenta, en gran parte debido a la influencia de C++, una extensión del lenguaje de programación C. Su dominación fue consolidada gracias al auge de las Interfaces gráficas de usuario, para las cuales la programación orientada a objetos está particularmente bien adaptada.

POO en lenguaje de programación C#.

C# es un lenguaje de programación orientado a objetos que utiliza clases y estructuras para implementar tipos como formularios Windows Forms, controles de interfaz de usuario y estructuras de datos. Una aplicación de C# típica se compone de clases definidas por el programador, junto con clases de .NET Framework.

C# ofrece varias maneras eficaces de definir clases, por ejemplo, proporcionar niveles de acceso diferentes, heredar características de otras clases y permitir que el programador especifique qué sucede cuando se crean o destruyen instancias de tipos.

OBJETOS ---> Los objetos son construcciones de programación que se componen de datos, comportamiento e identidad. Los datos del objeto se encuentran en los campos, propiedades y eventos del objeto; los métodos e interfaces del objeto definen los comportamientos del objeto. Los objetos tienen identidad, es decir, dos objetos con el mismo conjunto de datos no son necesariamente el mismo objeto.

En C#, los objetos se definen mediante classes y structs, que conforman el plano único a partir del cual operan todos los objetos de ese tipo.

MÉTODOS ---> Los métodos son un bloque de código que contiene una serie de instrucciones. En C#, cada instrucción se ejecuta en el contexto de un método.Los métodos se declaran en una clase o estructura especificando el nivel de acceso, el valor devuelto, el nombre del método y los parámetros de método. Los parámetros de método se incluyen entre paréntesis y separados por comas. Los paréntesis vacíos indican que el método no requiere ningún parámetro.

CAMPOS ---> Son objetos o valores contenidos en una clase o estructura. Los campos permiten a las clases y estructuras encapsular datos.Para mayor simplicidad, estos ejemplos utilizan campos que son public, pero esto no se recomienda en la práctica. Los campos generalmente deberían ser private. El acceso a campos por parte de clases externas debería ser indirecto, por medio de métodos, propiedades o indizadores.

FUNCIONES --> Una función es un módulo de un programa separado del cuerpo principal, que realiza una tarea específica y que puede regresar un valor a la parte principal del programa u otra función o procedimiento que la invoque.

La forma general de una función es:

Tipodato Nomfun(parametros)

{

cuerpo de instrucciones;

return [dato,var,expresión];

}

Donde tipo dato especifica el tipo de dato que regresará la función.

La instrucción RETURN es quien regresa un y sólo un dato a la parte del programa que la esté llamando o invocando, sin embargo es de considerar que RETURN puede regresar un dato, una variable o una expresión algebraica (no ecuación o fórmula) como lo muestran los siguientes ejemplos:

a) return 3.1416;

b) return area;

c) return x+15/2;

La lista de parámetros formales es una lista de variables separadas por comas (,) que almacenarán los valores que reciba la función; estas variables actúan como locales dentro del cuerpo de la función.

PROCEDIMIENTO ---> Un procedimiento es un grupo de instrucciones, variables, constantes, etc, que están diseñados con un próposito particular y tiene su nombre propio.

Es decir un procedimiento es un módulo de un programa que realiza tareas específicas y que no puede regresar valores al programa principal u a otro procedimiento que lo esté invocando.

Después de escribir un procedimiento se usa su propio nombre como una sola instrucción o llamada al procedimiento.

En C# Net su formato es void NomProc(){instrucciones;};

Un programa puede tener tantos procedimientos como se deseen, para hacer una llamada o invocación al procedimiento durante la ejecución de un programa sólo se deberá escribir el nombre del procedimiento y los paréntesis en blanco.

No hay comentarios: