Ejercicios resueltos en python (Parte 1) Ejercicios resueltos en python (Parte 1) miércoles, 29 de mayo de 2013 En esta entrada dejare mis soluciones a la primera parte de los ejercicios en Ejercicios Resueltos python, si no viste los ejercicios y quieres hacerlos antes de ver las soluciones acá dejo la entrada:Ejercicios en python (Parte 1) . Es importante decir que no existe una sola manera de resolver los ejercicios, cada persona se las ingenia con sus métodos o lógica. Es importante aclarar este punto porque puede ser que sus ejercicios estén distintos a los mios pero los resultados sean los mismos. Cualquier duda con los resultados dejar comentarios para poder acl ararlas. Ejercicio 1 #! /usr/bin/env python # -*- coding: utf-8 -*- def max (n1, n2): if n1 < n2: print n2 elif n2 < n1: print n1 else: print "Son iguales" Aclaro que uso el print para llamar a la función de la manera max(8, 5). También se puede usar return. Ejercicio 2 #! /usr/bin/env python # -*- coding: utf-8 -*- def max_de_tres (n1, n2, n3): if n1 > n2 and n1 > n3: print n1 elif n2 > n1 and n2 > n3: print n2 elif n3 > n1 and n3 > n2: print n3 else: print "Son iguales" Otra vez uso el print en ves del return. Dependiendo para que lo necesitemos se usa uno u el otro. En este caso solo quiero mostrar por pantalla cual es el mayor de los 3 números. Ejercicio 3 #! /usr/bin/env python # -*- coding: utf-8 -*- def largo_cadena (lista): cont = 0 for i in lista: cont += 1 return cont En este ejercicio utilizo return en ves de print. Para ver el resultado tendríamos que llamar la función de la manera: print largo_cadena ([1,2,3,4]) o print largo_cadena ("hola") Ejercicio 4 #! /usr/bin/env python # -*- coding: utf-8 -*- def es_vocal (x): if x == "a" or x == "e" or x == "i" or x == "o" or x == "u": return True elif x == "A" or x == "E" or x == "I" or x == "O" or x == "U": return True else: return False Ejercicio 5 #! /usr/bin/env python # -*- coding: utf-8 -*- def sum (lista): suma = 0 for i in lista: suma += i return suma def multip (lista): multiplicacion = 1 for i in lista: multiplicacion *= i return multiplicacion Ejercicio 6 #! /usr/bin/env python # -*- coding: utf-8 -*- def inversa (cadena): invertida = "" cont = len(cadena) indice = -1 while cont >= 1: invertida += cadena[indice] indice = indice + (-1) cont -= 1 return invertida Bueno reconozco que di muchas vueltas para resolver la palabra invertida. Quizá ustedes tengan una solución mas simple para los que recién se están iniciando. Cualquier cosa dejan un comentario y explico como funciona. Ejercicio 7 #! /usr/bin/env python # -*- coding: utf-8 -*- def inversa (cadena): invertida = "" cont = len(cadena) indice = -1 while cont >= 1: invertida += cadena[indice] indice = indice + (-1) cont -= 1 return invertida def es_palindromo (cadena): palabra_invertida = inversa (cadena) indice = 0 cont = 0 for i in range (len(cadena)): if palabra_invertida[indice] == cadena[indice]: indice += 1 cont += 1 else: print "No es palindromo" break if cont == len(cadena): #Si el contador = a la cantidad de letras de la cadena print "Es palindromo" # es porque recorrió todo el ciclo for y todas las # letras son iguales Como dije en el ejercicio anterior yo lo pensé así, pero deben haber formas mas fáciles de resolverlo.Yo utilizo los conocimientos que hasta la fecha tengo sobre python. Lo que hago en este ejercicio es utilizar la función del ejercicio anterior ( palabra invertida) para poder compararla con la cadena que nosotros deseemos. Ejercicio 8 #! /usr/bin/env python # -*- coding: utf-8 -*- def superposicion (lista1, lista2): for i in lista1: for x in lista2: if i == x: return True return False En esta función lo que hacemos es comparar dos listas. Ejercicio 9 #! /usr/bin/env python # -*- coding: utf-8 -*- def generar_n_caracteres (n, caracter): print n * caracter Ejercicio 10 #! /usr/bin/env python # -*- coding: utf-8 -*- def procedimiento (lista): for i in lista: print i * "x" Estaría bueno que dejen sus soluciones para comparar acá, o en l a entrada donde están propuestos los ejercicios. Compartir { 31 comentarios ... read them below or Comment } 1. Eneldo Serrata29 de mayo de 2013, 7:29 Buen post.. Responder Respuestas 1. Diego Caraballo29 de mayo de 2013, 7:37 Gracias, espero te sirva... Saludos 2. david vargas4 de julio de 2014, 17:14 def inversa2(x): cont="" for i in x: cont=i+cont print cont Responder 2. Anónimo30 de mayo de 2013, 10:50 ¡Hola otra vez! Así me quedaron algunas funciones: #Punto1: Algo mas corta :) def maximo(x,y): return x if x > y else y #Punto2: Llamando a la funcion anterior def max_de_tres_1(x,y,z): m = maximo(x,y) return maximo(m,z) # Y sin llamar a la funcion del punto1 def max_de_tres_2(x,y,z): if x > y and x > z: return x elif y > x and y > z: return y return z #Punto 3: Identico al que tienes :) #Punto4: Usando una lista para evitar los ifs (es una suerte de switch) def esVocal(caracter): vocales = ['a', 'e','i','o','u','A', 'E', 'I', 'O', 'U'] return caracter in vocales #Punto5: Identicos a los que tienes :D #Punto6: No pense en el tamaño... def inversa(secuencia): return secuencia[::-1] #Punto7:LLame a la funcion inversa def es_palindromo(cadena): # Solo para palabras return cadena == inversa(cadena) def es_frase_palindromo(frase): #Mas general, sirve para frases frase = frase.lower() frase = frase.replace(' ','') return es_palindromo(frase) # Punto8 y Punto9: Son iguales a los tuyos :D #Punto10: Llamo a la funcion del punto9 def procedimiento(lista): for numero in lista: print generar_n_caracteres(numero,'*') Como te comentaba, son muy buenos puntos para quienes estamos comenzando en Python. ¡Gracias! Responder Respuestas 1. manuel21 de julio de 2013, 10:34 ayuda como puedo resolver este problema. Es leer un archivo la cual contara todo las palabras y si la palabra esta repetida contar cuantas veces se repite y ponerlo en un diccionario, para ya después en listar en un archivo nuevo. con la palabra y el numero de repitiente Responder 3. Diego Caraballo30 de mayo de 2013, 16:29 Gracias a ti por el comentario. Ahora estoy en el trabajo, pero cuando llegue a casa me pongo a ver tus códigos que al parecer están muy buenos. Saludos Responder 4. Maria Gomez30 de mayo de 2013, 18:12 7_ def es_palindromo(palabra): y=0 x=-1 for i in range(len(palabra)/2): if palabra[y]==palabra[x]: y=y+1 x=x-1 return True else: return False Responder Respuestas 1. Diego Caraballo30 de mayo de 2013, 20:31 Muy bueno, voy a ver si lo analizo para encontrarle la lógica. Gracias por comentar... 2. Anónimo1 de junio de 2013, 20:01 def es_palindromo(word): return str(word) == str(word)[::-1] 3. Diego Caraballo2 de junio de 2013, 16:57 Esta muy bueno. Una forma bien sencilla de resolver la función es_palindromo(). Responder 5. MariaJesus19 de julio de 2013, 14:21 Hola , me podrian ayudar , tengo que crear una lista de 10 campos con números aleatorios el rango es de (1-25), en la lista no se deben repetir los números, por último debe imprimir la lista. Que debo hacer para que no se repitan los numeros? Responder Respuestas 1. Diego Caraballo19 de julio de 2013, 15:53 Hola María, se me ocurre esto para tu consulta. Saludos #! /usr/bin/env python # -*- coding: utf-8 -* import random lista = [] cant = 0 while cant <= 10: x = random.randrange(1, 26) if x not in lista: lista.append(x) cant += 1 print lista 2. manuel21 de julio de 2013, 11:47 ayuda como puedo resolver este problema porfavor. Es leer un archivo la cual contara todo las palabras y si la palabra esta repetida contar cuantas veces se repite y ponerlo en un diccionario, para ya después en listar en un archivo nuevo. con la palabra y el numero de repitiente Responder 6. Melina Morales28 de agosto de 2013, 19:50 Hola Disculpa podrias ayudarme con este problema Los números de empleados en una empresa están codificados de 100 a 199. Asuma que en un vector se ha almacenado los salarios/hora y en otro vector las horas trabajadas de los empleados de dicha empresa. Elabore un programa que lea n números de empleados y que calcule el salario bruto de cada empleado leído. es urgente GRACIAS!!!!! Responder 7. josemi30 de octubre de 2013, 10:19 El 7 de otra manera, igual menos elegante. def palindromos (x): longitud=len(x) rango=range(longitud) c=0 for z in rango: a=rango[z] b=(longitud-1)-a if str(x[a]) == str(x[b]): c=c+1 # Si la comparacion es correcta la anadimos al contador else: break #print "No palindromo" if c == longitud: # Todas las comparaciones son OK? han de ser como la longitud return "Si es Palindromo" else: return "No es Palindromo" Responder 8. Anónimo7 de diciembre de 2013, 15:16 Hola! Creo que la solución al ejercicio 2 no es del todo correcta, con esa implementación al hacer la siguiente llamada: max_de_tres(3,3,1) La salida sería "Son iguales", en lugar de "3", que creo que es lo más correcto. Yo había pensado en algo como: def max_de_tres (num1, num2, num3): ret =num3 if num1 >= num2 and num1>=num3: ret = num1 elif num2>=num1 and num2>=num3: ret = num2 return ret Responder Respuestas 1. Diego Caraballo12 de diciembre de 2013, 12:43 Buen aporte, no me había dado cuenta. Gracias por ayudar. Saludos Responder 9. Marcos Mazini7 de enero de 2014, 10:53 Hola, encontré una solución más sencilla al ejercicio 6, el de invertir un texto y sin usar [::-1]. def inversa(texto): ---- invertida = "" ---- for letra in texto: -------- invertida = letra + invertida ---- return invertida Saludos! Responder 10. Anónimo6 de febrero de 2014, 17:51 # -*- coding: utf-8 -*- def histograma(num1, num2, num3): h = '*' a = h * num1 b = h * num2 c = h * num3 print a print b print c histograma(3,3,1) Responder 11. Anónimo27 de febrero de 2014, 12:01 por que hacen preguntas tan tontas, python es muy facil, los que no saben hagan un curso y no nos hagan perder tiempo Responder 12. Anónimo5 de marzo de 2014, 13:38 hay diferentes formas de resolver los problemas no necesariamente como los ejercicos que estan aki cualkier problema me mandan un imbox :) saludos desde la universidad de bruselas - Belgica Responder 13. Rodrigo Zamora5 de marzo de 2014, 16:52 Hola muy buen post, estoy empezando con python y verdad que es bonito este lenguaje. mis soluciones solo difieren en la 4, 6 y 7 quedando asi: ejercicio 4: def vocal(dato): vocals = 'aeiouAEIUO' if vocals.find(dato)==-1: print('no es vocal') else: print('SI es vocal') ejercicio 6: def inversa(cr): cr = list(cr) ncr = [] c = len(cr) - 1 for x in range(c, -1, -1): ncr.append(cr[x]) return ''.join(ncr) ejercicio 7: def palindromo(p): p = list(p) #copia de la palabra, que sera recorrida inversamente o = p #cadena original t = len(p) - 1 #tamaño de cadena c = -1 #contador for x in range(t, -1, -1): if p[x] == o[t-x]: c += 1 if c == t: return 'es palindromo' else: return 'NO es palindromo' Saludos y buen post, ojala puedas poner mas ejercicios interesante, que vayan subiendo de complejidad. Responder 14. charles leyva18 de marzo de 2014, 20:05 Que tal, el ejercico 4 vi una manera de hacerlo diferente def devuelve(letras,string): count = 0 for i in range(len(letras)): if string[0] == letras[i]: return True for x in range(len(letras)): if string[0] != letras[i]: return False letras =['a','e','i','o','u'] a = raw_input("Ingresa una variable \n").lower() contador = 0 for i in a: contador += 1 if contador == 1: print devuelve(letras, a) else: print "Debes Ingresar un solo caracter \n" Responder 15. Anónimo1 de abril de 2014, 13:45 El ejercicio 4. def sum (lista): suma = 0 for i in lista: suma += i return suma def multip (lista): multiplicacion = 1 for i in lista: multiplicacion *= i return multiplicacion ninguno de los dos me corre, ayudenme tengo python 3.4 Responder Respuestas 1. Diego Caraballo11 de abril de 2014, 10:38 Los ejercicios están realizados en python 2.7. Saludos Responder 16. S. M. C.10 de abril de 2014, 20:10 hola como stas Diego, stoy studiando este programa que es fabuloso, pero he quedado atascado en un simple problema... visualizo la solucion pero me es esquiva... Escribir un programa para ser usado por el concejo de estudiantse en las proximas elecciones. El programa listara, y enumerara tres candidatos para presidente, entoncs deja entrar los votos hasta que al ingresar cero el programa dara como resultado qien gano, que porcentaje gano cada candidato... 1. Diego Caraballo 2. Sandro Cruz 3. Luis Perez son los candidatos... lo que no puedo es obteer el numero de votantes mediante el conteo de cada voto, puesto que cada voto representa un votante... gracias de antemano Responder 17. Diego Caraballo11 de abril de 2014, 10:36 Hola S.M.C, no has probado hacerlo usando contadores? Después haces los promedios para calcular el porcentaje... Después lo hago y te cuento, gracias por escribir... Responder 18. Andres Zapata17 de mayo de 2014, 7:51 buenos dias tengo esta consulta sera que me pueden ayudar conn esto multiplique dos numeros usando cadenas..... Responder Respuestas 1. Andres Zapata17 de mayo de 2014, 10:07 por favor le agradezco al que me colabore rapido con esto Responder 19. ed20 de junio de 2014, 12:33 Buen post, te felicito hermano. Responder 20. pepe TZ1 de agosto de 2014, 16:53 Hola buenas, primero decir que me ha gustado tu post, soy nuevo en python y para practicar me ha venido muy bien jaja. He modificado el apartado 10 (el del histograma) para que las estrellitas (*) salgan en vertical en vez de en horizontal. Dejo aquí el código por si alguien le quiere echar un vistazo: #restar uno a cada elemento de la lista que sea igual al maximo def resta_uno_lista(lista,maximo): for i in range(0,len(lista)): if(lista[i]==maximo): lista[i]-=1 return lista #genera un histograma con * apartir de una lista de numeros def histograma(valores): maximo = max(valores) maximoIndice = max(valores) for j in range(0,maximoIndice): for i in valores: if (maximo == i): print('*'), else: print(' '), print('') #restar uno a cada elemento de la lista que sea igual al maximo valores=resta_uno_lista(valores,maximo) maximo-=1