Aprende a programar desde cero: Condicionales

Esta es una serie de artículos donde discutimos conceptos básicos de programación de una forma intuitiva, por medio de ejemplos.

En esta ocasión aprenderemos sobre los condicionales, para que sirven y como usarlos.

Que son los condicionales

Los condicionales nos permiten escoger entre diferentes acciones según la respuesta a un interrogante.

Por ejemplo:

  • Si cuesta menos de $10.000 me lo compro.
  • Si no llueve me pongo el vestido rojo.

En estos ejemplos la acción a seguir depende de la respuesta a un interrogante, por lo que la acción cambia si la respuesta es si (Verdadera/True) o no (Falsa/False).

Las partes de una condición son:

  • La incógnita: si pasas el curso
  • La acción que tomamos si la respuesta es verdadera: comprar bicicleta
  • Opcional: una consecuencia si no se cumple: te quedas sin TV 1 mes.

enter image description here

Podemos hacer preguntas mas complicadas uniendo varias preguntas mas pequeñas con los conectores Y y O, como por ejemplo:

Si me pagan y no llueve vamos a piscina

Si no paga no se va a piscina
Si llueve tampoco se va a piscina
Solo si las dos se cumplen

Condiciones en programación

Las condiciones nos permiten inspeccionar las variables de nuestro programa con el fin de responder preguntas necesarias para resolver un problema.

Por ejemplo, si estamos haciendo una calculadora; casi todas las operaciones matemáticas básicas se pueden realizar entre cualquier numero, menos la división, la cual no se puede hacer entre cero.

Ya que las entradas a nuestra calculadora son hechas por el usuario, no hay nada que podamos hacer para impedir que este ingrese el numero que quiera.

Lo que si podemos hacer es inspeccionar dichos números para verificar que las condiciones necesarias para la correcta ejecución de nuestro programa se cumplan:

int dividendo = 10;
int divisor = 0; // imagina que lo ingreso el usuario

if (divisor === 0) {
	// mostrar mensaje de error
} else {
	// el divisor no es cero por lo que se puede proceder
	float resultado = dividendo / divisor;
	// mostrar resultado
}

Sintaxis de un condicional

La forma de escribir el condicional varia dependiendo del lenguaje, pero por lo general tienen la siguiente forma:

Lenguajes con sintaxis similar a c (java, c#, c++, php, javascript…)

if (condición dentro de paréntesis) {
  // lo que se ejecuta si es cierta la condición
  // va dentro de corchetes/llaves
} else { // <-- opcional
  // lo que se desea ejecutar si es falsa
  // también va dentro de corchetes/llaves
}

En caso de que existan múltiples condiciones podemos usar un else if (sino si). En este caso se ejecutara el primer bloque cuya condición sea cierta y se descartaran los demás.

if (<primera-condición>) {
	// acciones
} else if (<segunda-condición>) {
	// acciones
} else { // ninguna de las condiciones se cumple
   // acciones
}

Como hacemos “preguntas” en un condicional

Existen diferentes operadores que nos permiten hacer preguntas acerca de las variables con el fin de tomar una decisión.

símbolo significado
== Compara si dos valores son iguales
!= Compara si dos valores son diferentes
> Compara si el valor de la izquierda es mayor que el de la derecha
< ¿Es el valor de la izquierda menor que el de la derecha?
>= ¿Es el valor de la izquierda mayor o igual al de la derecha?
<= ¿Es el valor de la izquierda menor o igual al de la derecha?

Si queremos crear una pregunta mas compleja podemos conectar varias preguntas mas pequeñas usando conectores lógicos como:

Símbolo significado
&& Tanto la parte izquierda como derecha son verdaderas
|| Alguna o ambas partes de la condición son verdaderas

Nota: en algunos lenguajes como python se usa or y and en lugar de || y &&

Como podemos ver, en programación el significado de O (||) es muy diferente al que usamos al hablar.

Cuando usamos el conector O al hablar, se debe elegir una sola opción entre varias, por ejemplo: “Puedes comer pollo o carne”, Quieren decir que solo podemos comer una de ellas, pero no las dos.

En programación cuando usamos O (||), la condición se cumple si una o varias de las “incógnitas” individuales se cumplen:

int a = 3
// dos de las tres "incógnitas" se cumplen
// por lo que la condición se cumple
if (a < 3 || a < 5 || a > 10) {
	// acciones
}

Ejemplo practico

Imagina que estas creando un juego de pocker y deseas calcular los puntos que obtiene un jugador.

Para simplificar las cosas descartemos los tipos y solo verifiquemos los valores, existen varios tipos de mano:

  • Pares
  • Full
  • Escalera

¿Como sabes el puntaje de un jugador? usando condicionales

// las cartas están guardas en variables c1, c2... hasta la cinco
// para facilitar las cosas se encuentran ordenadas de mayor a menor
if (c1 == c2 && c2 == c3 && c3 == c4) {
   // poker
} else if (c1-c2 == 1 && c2-c3 == 1 && c3-c4 == 1 && c4-c5 == 1) {
   // escalera
} else if (<?>) {
   // doble pares
}

¿Que condición debe ir en el ultimo else if para saber si es un doble par?

Conclusión

Con esto concluimos la parte dedicada a los condicionales, si tienes alguna pregunta no dudes en dejarla en los comentarios.

Variables

Aprende a programar desde cero: Variables

Esta es una serie de artículos donde discutimos los conceptos básicos de la programación de una forma intuitiva, por medio de ejemplos.

En esta ocasión aprenderemos sobre las variables, para que sirven y como usarlas en la practica.

[toc]

Que son las variables

Las variables son una especie de contenedor que nos permite guardar un dato para luego poder recuperarlo de forma fácil y rápida por medio del nombre que le asignamos.

En este sentido las variables se asemejan mucho a una caja con una etiqueta.

Variables

Imagina lo siguiente:

Tu cuarto es un desorden y hay un montón de cosas que ya no usas, así que decides guardarlas.

Tienes dos alternativas:

  1. Amontonar todo en un solo sitio.
  2. Usar cajas marcadas según su contenido

El problema con la primera opción es que si luego quieres volver a utilizar, por ejemplo, tu viejo gameboy, tendrás que sacar cosa por cosa para encontrar lo que deseas.

Si en lugar de eso acomodas las cosas en cajas marcadas, luego sera mucho mas fácil encontrarlas lo que deseas.

Las variables guardan datos y se identifica por medio de un nombre.

Para que sirven

Las variables nos permiten reutilizar una solución.

Una vez encontramos la solución a un problema, muy seguramente podemos aplicar la misma solución a problemas similares si identificamos las partes que cambian (varían) y las sustituimos.

Un ejemplo de esto son las formulas matemáticas.

Pitagoras halló la forma de calcular la hipotenusa de un triangulo rectángulo, con su teorema podemos resolver cualquier triangulo rectángulo con solo sustituir las variables con nuevos valores.

Teorema de Pitágoras

Un ejemplo “mas practico” son los formatos de documentos, donde solo debemos sustituir los campos en blanco con los datos requeridos.

Aquí podemos identificar otra parte importante de las variables: el tipo de dato.

El tipo de dato es el conjunto de valores que una variable puede tomar. Si vemos el siguiente formato de permiso, solo ciertos valores tienen sentido en cada campo.

Formato de permiso

En los campos de nombres y motivo no tiene sentido escribir puros números, así como en los de día, año curso y teléfono puras letras.

Las variables solo tienen un conjunto de valores posibles (tipo de dato)

Una definición informal

Con lo visto anteriormente podemos decir que:

Una variable nos permite almacenar un valor de cierto tipo para su posterior recuperación por medio de su nombre.

Variables en la practica

Ahora que tenemos una idea mas clara sobre que es una variable, es momento de ponerlo en practica.

Como crear una variable

La creación de una variable se divide en:

  • Definición: le damos un nombre y especificamos el tipo de dato.
  • Inicialización: Asignamos un valor a la variable.

Como crear una variable

En los lenguajes de tipado dinámico no se especifica un tipo de dato he incluso podemos cambiar el contenido de una variable de un entero a un float o un string – Aunque no deberíamos hacerlo, ya que ésto genera confusión.

Ejemplos de lenguajes de tipado dinámico son son javascript, php y python.

Tipos de datos

Si bien los tipos de datos dependen del lenguaje que estemos utilizando, existen algunos tipos básicos que siempre encontraremos:

TIPO DE DATO DESCRIPCIÓN
int Números enteros
float Números con decimales
boolean Valor logico (vardadero o falso)
string Texto
Arreglos Conjunto de datos del mismo tipo

En lenguajes con tipado estático es necesario especificar que tipo de dato deseamos guardar en la variable y no es posible almacenar un dato que no sea del tipo que especificamos:

int entero = 10;
float decimal = 1.3;
String texto = "hola mundo!"
// Esto genera un error
texto = 10;

En lenguajes de programación con tipado dinámico no es necesario especificar el tipo de variable.

// javascript
var entero = 10;
var decimal = 1.23
var texto = "hola mundo!"
// es posible cambiar el tipo de dato, pero no deberíamos hacerlo
texto = 10;

Nombres de las variables

Las reglas para la creación de nombre de variables dependen del lenguaje, por lo que debes consultar la documentación del mismo para estar seguro; pero por lo general:

  • Tienen que empezar con una letra o un guion bajo. Algunas excepciones:
    • En PHP tienen que empezar con el signo $
    • En javascript pueden empezar con el signo $.
  • No pueden contener espacios
  • Solo puede contener letras, números y el guion bajo (_)
    • En javascript también pueden contener el signo $

Ejemplo:

// lenguaje java
int edad = 10;
String nombre_completo = "John Smith";
// Incorrecto
String Nombre completo = "foo"; // contiene espacios
float 3pedro = 10.1; // empieza con un numero

Buenas practicas

Cualquier tonto puede escribir código que un ordenador entienda. Los buenos programadores escriben código que los humanos pueden entender. Martin Fowler

Gran parte de nuestra vida como desarrolladores la pasaremos corrigiendo errores (bugs), agregando nuevas características y en general manteniendo programas existentes. Es por esto que debemos hacer que nuestros programas sean fáciles de entender.

  • Los nombres de las variables deben ser descriptivos, incluso si esto significa que sean largos (sin excederse).
// que ~%$*#@ hace esta función
function f(a, c, m) {
	return a * Math.pow(1 + c, m);
}

Puede que en el momento nos parezca obvio lo que hace esta función, pero ¿lo seguirá siendo 1 mese después?, ¿que tal 10 meses después? o ¿seguiremos siendo nosotros los que mantengamos el código?.

Recuerda:

Codifica siempre como si la persona que fuera a mantener tu código fuera un asesino en serie maníaco que sabe donde vives

// mucho mejor
function interesCompuesto(capital_inicial, porcentaje, tiempo) {
	return capital_inicial * Math.pow(1 + porcentaje, tiempo);
}
  • Ser consistentes a la hora de nombrar nuestras variables. Si los nombres de nuestras variables siguen un patrón predecible, serán mucho mas fácil de recordar y disminuiremos la posibilidad de cometer errores.
int Mi_Entero = 10;
String miString = "Hola ";
float mifloat = 10.1;
// varias lineas mas abajo o incluso en otro archivo
// no recordamos como llamamos a nuestra variable
mostrarMensaje(mistring + " Juan");

Conclusión

Con esto concluimos la primera parte de este “mini-curso” sobre programación, en el proximo articulo hablaremos sobre las iteraciones.

Si te gusto no olvides compartirlo, y si tienes alguna pregunta déjala en los comentarios.

Tablet nueva, juegos rotos.

Hace pocos días llego por fin mi tableta (una gallaxy tab 2) y como podrán imaginar lo primero que hice fue probar los juegos que he desarrollado y para mi sorpresa varios de ellos no funcionaban correctamente; en algunos se veía un segundo canvas con la misma imagen y en otros el contenido previo no se borraba. Al parecer es un problema ya viejo con clearRect que afecta a android 4.1. Lo primero que se me ocurrió para solucionar el problema fue el viejo truco de re-definir el tamaño del canvas:
canvas.width = canvas.width;
Ahora si que funcionaban, pero algunas acciones como el arrastrar eran realmente lentas (especialmente al arrastrar y soltar); el problema con este método es que ademas de borrar el contenido del canvas, también restablece su estado (fillStyle, clearStyle, scale, translate, shadowColor….) lo que al parecer influye en el rendimiento (al menos en el gallaxy tab – único dispositivo que tengo para hacer pruebas). Otra de las soluciones sugeridas para eliminar el problema del canvas duplicado que encontré era el quitar el estilo overflow: hidden de todos los elementos padres del canvas, aunque el problema desapareció al igual que en el método anterior el rendimiento era pésimo.

Solución

Hasta el momento la solución con los mejores resultados es la de usar un color solido como fondo para el canvas y al momento de borrar el contenido usar fillRect en lugar de clearRect
<canvas style="background: #fff;"></canvas>
function clear(ctx) {
    ctx.fillStyle = "#fff";
    ctx.fillRect(0, 0, ctx.canvas.width, ctx.canvas.height);
}
El aumento en rendimiento es considerable, sobre todo en juegos que requieren arrastrar y soltar (como el solitario). Aun así esta no es una solución definitiva ya que al usar un color solido no es posible apilar canvas para crear capas.
¿Conoces alguna mejor solución? déjala en los comentarios.

Easy QR Code: Mi primera extensión para chrome


tltr: Hice una extensión para chrome que genera códigos QR con tan solo dos clics (descarguen aquí). Si les gusta compartan/comenten en twitter/facebook (quiero ser famoso *¬*).

Los códigos QR son una forma de almacenar información en un código de barras en dos dimensiones, y son una muy buena forma de copiar enlaces y texto a nuestros dispositivos móviles en lugar de tener que copiarlos a mano.

En la tienda de extensiones de chrome no encontré ninguna que cumpliera mis necesidades (rápido y simple de usar), mucha de las “extensiones” son simples enlaces a paginas y requieren muchos pasos:
  1. Copiar texto/enlace
  2. Clic para abrir la “Extensión”
  3. Pegar texto en un formulario
  4. Clic para generar el código
Demasiado extenuante para un simple código, en mi extensión ideal solo se necesita:
  1. Clic derecho sobre texto/enlace
  2. Seleccionar generar código
Listo. adicionalmente el código debe generarse rápidamente. con estas especificaciones y armado con una librería para generar códigos QR y la documentación del API de extensiones de chrome y dos cojones nació mi primera extensión para google chrome: Easy QR Code.

A continuación el enlace a la extensión y un corto vídeo de su funcionamiento.


Mi obsesión con el anime


Los que me conocen saben que estoy interesado en una variedad de cosas, pero suelo distraerme con facilidad, y lo que mas me distrae (o ¿en lo que mas me concentro?) es el anime.

De tiempo en tiempo me engancho tanto con alguna serie que termino buscando de todo sobre ésta: Fondos de pantalla, openings/endings, AMV, posters motivacionales (tengo alrededor de 20.000 en mi pc) y noticias entre otros. El problema es que no se de ningún sitio que contenga todo este material, todo lo recolecto de diferentes lugares como foros, youtube, google images… y esto me quita mucho tiempo.

Alguien dirá que la solución es muy simple: que deje de buscar pendejadas y me ponga a trabajar. Pero el anime es una forma de distraerme del día a día, ademas el contenido de estos (historia/humor/personajes…) es mucho mas rico que el de muchas películas y programas de televisión, incluso hay algunos que dejan enseñanzas sobre la vida y esas cosas u_u.

Si saben de algún un sitio donde se pueda encontrar este contenido concentrado, con animes/manga clasificados por géneros (gore, echi, shounen…) Dejen el link en los comentarios.