Ejercicios Resueltos en Python 1

26
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 aclararlas. Ejercicio 1 #! /usr/bin/env python # -*- coding: utf-8 -*- def max (n1, n2): if n1 < n2: print n2 elif n2 < n1: print n1 else:

Transcript of Ejercicios Resueltos en Python 1

Page 1: Ejercicios Resueltos en Python 1

Ejercicios resueltos en python (Parte 1)

Ejercicios resueltos en python (Parte 1)

miércoles, 29 de mayo de 2013En 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 aclararlas. 

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:

Page 2: Ejercicios Resueltos en Python 1

        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]) oprint 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:

Page 3: Ejercicios Resueltos en Python 1

        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

Page 4: Ejercicios Resueltos en Python 1

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 la entrada donde están propuestos los ejercicios.Compartir

Page 6: Ejercicios Resueltos en Python 1

2.

david vargas 4 de julio de 2014, 17:14

def inversa2(x):cont=""for i in x:cont=i+contprint 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 anteriordef max_de_tres_1(x,y,z):m = maximo(x,y)return maximo(m,z)

# Y sin llamar a la funcion del punto1def max_de_tres_2(x,y,z):if x > y and x > z:return xelif y > x and y > z:return yreturn 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 inversadef es_palindromo(cadena): # Solo para palabrasreturn cadena == inversa(cadena)

Page 7: Ejercicios Resueltos en Python 1

def es_frase_palindromo(frase): #Mas general, sirve para frasesfrase = frase.lower()frase = frase.replace(' ','')return es_palindromo(frase)

# Punto8 y Punto9: Son iguales a los tuyos :D

#Punto10: Llamo a la funcion del punto9def 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!

ResponderRespuestas

1.

manuel 21 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

Page 8: Ejercicios Resueltos en Python 1

3.

Diego Caraballo 30 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

Page 9: Ejercicios Resueltos en Python 1

4.

Maria Gomez 30 de mayo de 2013, 18:12

7_def es_palindromo(palabra):y=0x=-1for i in range(len(palabra)/2):if palabra[y]==palabra[x]:y=y+1x=x-1return Trueelse:return False

ResponderRespuestas

Page 10: Ejercicios Resueltos en Python 1

1.

Diego Caraballo 30 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]

Page 11: Ejercicios Resueltos en Python 1

3.

Diego Caraballo 2 de junio de 2013, 16:57

Esta muy bueno. Una forma bien sencilla de resolver la función es_palindromo().

Responder

5.

MariaJesus 19 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?

ResponderRespuestas

Page 12: Ejercicios Resueltos en Python 1

1.

Diego Caraballo 19 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.

Page 13: Ejercicios Resueltos en Python 1

manuel 21 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 Morales 28 de agosto de 2013, 19:50

HolaDisculpa podrias ayudarme con este problemaLos 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 urgenteGRACIAS!!!!!

Responder

7.

josemi 30 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)-aif str(x[a]) == str(x[b]):c=c+1 # Si la comparacion es correcta la anadimos al contadorelse:break#print "No palindromo" if c == longitud: # Todas las comparaciones son OK? han de ser como la longitudreturn "Si es Palindromo"else:return "No es Palindromo"

Responder

Page 14: Ejercicios Resueltos en Python 1

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 =num3if num1 >= num2 and num1>=num3:ret = num1elif num2>=num1 and num2>=num3:ret = num2return ret

ResponderRespuestas

1.

Page 15: Ejercicios Resueltos en Python 1

Diego Caraballo 12 de diciembre de 2013, 12:43

Buen aporte, no me había dado cuenta. Gracias por ayudar.Saludos

Responder

9.

Marcos Mazini 7 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.

Page 16: Ejercicios Resueltos en Python 1

Anónimo6 de febrero de 2014, 17:51

# -*- coding: utf-8 -*-

def histograma(num1, num2, num3):h = '*'a = h * num1b = h * num2c = h * num3print aprint bprint 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

Page 17: Ejercicios Resueltos en Python 1

13.

Rodrigo Zamora 5 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 = []

Page 18: Ejercicios Resueltos en Python 1

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 inversamenteo = p #cadena originalt = len(p) - 1 #tamaño de cadenac = -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

Page 19: Ejercicios Resueltos en Python 1

14.

charles leyva 18 de marzo de 2014, 20:05

Que tal, el ejercico 4 vi una manera de hacerlo diferente 

def devuelve(letras,string):count = 0for i in range(len(letras)):if string[0] == letras[i]:return Truefor 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 = 0for i in a:contador += 1if contador == 1:print devuelve(letras, a)else:print "Debes Ingresar un solo caracter \n"

Page 20: Ejercicios Resueltos en Python 1

Responder

15.

Anónimo1 de abril de 2014, 13:45

El ejercicio 4. def sum (lista):suma = 0for i in lista:suma += ireturn suma

def multip (lista):multiplicacion = 1for i in lista:multiplicacion *= ireturn multiplicacion

ninguno de los dos me corre, ayudenme tengo python 3.4

ResponderRespuestas

1.

Page 21: Ejercicios Resueltos en Python 1

Diego Caraballo 11 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 Caraballo2. Sandro Cruz3. Luis Perezson 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

Page 22: Ejercicios Resueltos en Python 1

17.

Diego Caraballo 11 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 Zapata 17 de mayo de 2014, 7:51

buenos dias tengo esta consulta sera que me pueden ayudar conn estomultiplique dos numeros usando cadenas.....

ResponderRespuestas

1.

Andres Zapata 17 de mayo de 2014, 10:07

Page 23: Ejercicios Resueltos en Python 1

por favor le agradezco al que me colabore rapido con esto

Responder

19.

ed 20 de junio de 2014, 12:33

Buen post, te felicito hermano.

Responder

20.

pepe TZ 1 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 maximodef resta_uno_lista(lista,maximo):for i in range(0,len(lista)):if(lista[i]==maximo):lista[i]-=1return lista

#genera un histograma con * apartir de una lista de numerosdef 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 maximovalores=resta_uno_lista(valores,maximo)maximo-=1