Categoría: Solución 1ra Evaluación

  • s1Eva_IT2016_T2 historial de visitas web

    Ejercicio: 1Eva_IT2016_T2 historial de visitas web

    literal a. Se obtiene un registro de los sitios visitados, para luego separar sus partes entre empleado|sitio|duracion.

    Para los sitios que no son de trabajo se usa una lista llamada ocio. Si el sitio visitado no se encuentra en trabajo, se añade a la lista ocio. Se considera revisar que la lista no tenga elementos repetidos

    # a) sitios que no son de trabajo
    ocio = []
    n = len(visitados)
    i = 0
    while not(i>=n):
        registro = visitados[i]
        partes = registro.split('|')
        sitio  = partes[1]
        if not(sitio in trabajo):
            if not(sitio in ocio):
                ocio.append(sitio)
        i = i + 1
    

    literal b. Par contabilizar el tiempo por empleado se acumula en una lista los tiempos de navegación, usando la posición del empleado en la lista obtenida con la instrucción empleados.index(quien)

    # b) tiempo de internet/empleado
    m = len(empleados)
    tiempo = np.zeros(m,dtype=int)
    
    n = len(visitados)
    i = 0
    while not(i>=n):
        registro = visitados[i]
        partes = registro.split('|')
        quien  = partes[0]
        indice = empleados.index(quien)
        cuanto = int(partes[2])
        tiempo[indice] = tiempo[indice] + cuanto
        i = i + 1
    

    Se procede de forma semejante para obtener una tabla de tiempos por sitio.

    Una respuesta que se pude obtener de la tabla anterior es la búsqueda del empleado más ocioso, el que ha usado más tiempo en sitios de ocio. (tema 3, literal f)


    Algoritmo en Python

    # CCPG1001 Fundamentos de Programación FIEC-ESPOL
    # 1Eva_IT2016_T2 historial de visitas web
    import numpy as np
    
    # INGRESO
    visitados = [ 'maria2|www.facebook.com|160',
                  'xavi7|www.eluniverso.com|50',
                  'jose15|www.sri.gob.ec|30',
                  'maria2|www.twitter.com|30',
                  'xavi7|www.inec.gob.ec|10',
                  'maria2|www.espol.edu.ec|50',
                  'jose15|www.sri.gob.ec|120',
                  'xavi7|www.sri.gob.ec|20',
                  'maria2|www.twitter.com|20',]
    empleados = ['maria2',
                 'jose15',
                 'xavi7']
    trabajo = ['www.espol.edu.ec',
               'www.inec.gob.ec',
               'www.sri.gob.ec']
    
    # PROCEDIMIENTO
    
    # a) sitios que no son de trabajo
    ocio = []
    n = len(visitados)
    i = 0
    while not(i>=n):
        registro = visitados[i]
        partes = registro.split('|')
        sitio  = partes[1]
        if not(sitio in trabajo):
            if not(sitio in ocio):
                ocio.append(sitio)
        i = i + 1
    
    # b) tiempo de internet/empleado
    m = len(empleados)
    tiempo = np.zeros(m,dtype=int)
    
    n = len(visitados)
    i = 0
    while not(i>=n):
        registro = visitados[i]
        partes = registro.split('|')
        quien  = partes[0]
        indice = empleados.index(quien)
        cuanto = int(partes[2])
        tiempo[indice] = tiempo[indice] + cuanto
        i = i + 1
    
    # b) tiempo de internet por empleado/sitio. matrices
    k = len(visitados)
    n = len(empleados)
    todositio = trabajo + ocio
    m = len(todositio)
    tabla = np.zeros(shape=(n,m), dtype=int)
    
    i = 0
    while not(i>=k):
        registro = visitados[i]
        partes = registro.split('|')
        quien  = partes[0]
        fila   = empleados.index(quien)
        donde  = partes[1]
        columna = todositio.index(donde)
        cuanto = int(partes[2])
        tabla[fila,columna] = tabla[fila,columna] + cuanto
        i = i+1
    
    # Tema 3. f)
    # empleado es mas ocioso
    parte = tabla[:,len(trabajo):]
    ocioempleado = np.sum(parte, axis =1)
    masocioso = np.argmax(ocioempleado)
    quien = empleados[masocioso]
    
    # SALIDA
    print('sitios de ocio: ')
    print(ocio)
    print('tiempos por empleado: ')
    print(tiempo)
    print('tabla de tiempos: ')
    print(tabla)
    print('empleado mas ocioso: ', quien) 
    

    resultado del algoritmo

    sitios de ocio: 
    ['www.facebook.com', 'www.eluniverso.com', 'www.twitter.com']
    tiempos por empleado: 
    [260 150  80]
    tabla de tiempos: 
    [[ 50   0   0 160   0  50]
     [  0   0 150   0   0   0]
     [  0  10  20   0  50   0]]
    empleado mas ocioso:  maria2
    >>> 
    
  • s1Eva_IT2014_T2 Verificar EAN con Python

    Ejercicio: 1Eva_IT2014_T2 Verificar EAN

    [ algoritmo ] [ diagrama flujo ] codigo de barras EAN

    Para un número EAN dado, de cualquier producto, se ingresa como un número entero.

     

    # INGRESO
    EAN = int(input('European Article Number,EAN: '))
    

    Se requiere separar los componentes usando cociente y residuo: producto, empresa y país según las posiciones y cantidad de dígitos.

    # PROCEDIMENTO
    # separar las partes
    verificador = EAN%10 # un dígito
    numero = EAN//10
    
    producto = numero%100000 # cinco dígitos
    numero =  numero//100000
    
    empresa =  numero%10000 # cuatro dígitos
    pais =  numero//10000

    Luego encontrar la suma de los dígitos con la operación indicada en el enunciado.

    La siguiente semana de ser necesario se explica el tema de la decena superior.

    [ algoritmo ] [ diagrama flujo ]

    ..


    Algoritmo en Python

    # ICM00794-Fundamentos de Computación - FCNM-ESPOL
    # 1Eva_IT2014_T2 Verificar EAN
    
    # INGRESO
    EAN = int(input('European Article Number,EAN: '))
    
    # PROCEDIMENTO
    # separar las partes
    verificador = EAN%10  # un dígito
    numero = EAN//10
    
    producto = numero%100000 # cinco dígitos
    numero =  numero//100000
    
    empresa =  numero%10000  # cuatro dígitos
    pais =  numero//10000
    
    # calcular verificador
    suma = 0
    numero = numero = EAN//10
    while not(numero<=0):
        digito = numero%10
        numero = numero//10
        suma   = suma + 3*digito
        
        digito = numero%10
        numero = numero//10
        suma   = suma + 1*digito
        
    decena    = suma//10
    superior  = (decena + 1)*10
    calculado = superior - suma
    
    if (verificador == calculado):
        valido = 1
    else:
        valido = 0
        
    # SALIDA
    print('el numero ingresado es válido: ', valido)
    print('producto: ', producto)
    print('empresa: ', empresa)
    print('pais: ', pais)
    

    resultado del algoritmo

    European Article Number,EAN: 7702004003508
    el numero ingresado es válido:  1
    producto:  350
    empresa:  2004
    pais:  770
    >>> 
    
    European Article Number,EAN: 7702004003509
    el numero ingresado es válido:  0
    producto:  350
    empresa:  2004
    pais:  770
    >>> 
    

    [ algoritmo ] [ diagrama flujo ]
    ..


    Diagrama de Flujo

    Diagrama según taller realizado en aula. tenía una sección de tarea.

    [ algoritmo ] [ diagrama flujo ]

  • s1Eva_IIT2014_T3 Parasailing sin sobrecarga, parejas

    Ejercicios: 1Eva_IIT2014_T3 Parasailing sin sobrecarga, parejas

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]

    El ejercicio consiste en una revisión ordenada del peso de cada persona a participar con una posible pareja.

    i 1 2 3 ...
    pesos[i] 120 180 165 ...

    Los pesos de cada persona se registran en un arreglo.

    # INGRESO
    capacidad = int(input('capacidad de equipo: '))
    n = int(input('personas en cola: '))
    
    peso = np.zeros((n+1),dtype=int)
    i = 1
    while (i<=n):
        peso[i] = int(input("Peso[ "+str(i)+"]:"))
        i = i + 1
    

    El algoritmo comienza revisando una persona i junto a otra persona j. Si la pareja no sobrecarga el paracaidas, se cuenta y registra la pareja posible de participar en un solo viaje de parasailing.

            s = peso[i] + peso[j]
    
            # revisa capacidad
            if (s<=capacidad):
                parejas = parejas + 1
                posibles.append([i,j])

    Use un contador y una lista para el registro.

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]
    ..


    Algoritmo en Python

    # ICM00794-Fundamentos de Computación - FCNM-ESPOL
    # 1Eva_IIT2014_T3 Parasailing sin sobrecarga, parejas
    # propuesta solucion: edelros@espol.edu.ec
    
    import numpy as np
    
    # INGRESO
    capacidad = int(input('capacidad de equipo: '))
    n = int(input('personas en cola: '))
    
    peso = np.zeros((n+1),dtype=int)
    i = 1
    while (i<=n):
        peso[i] = int(input("Peso[ "+str(i)+"]:"))
        i = i + 1
    
    # PROCEDIMIENTO
    
    # busca parejas
    posibles = []
    parejas = 0
    i = 1
    while (i<n):
        j = i + 1
        while (j<=n):
            s = peso[i] + peso[j]
    
            # revisa capacidad
            if (s<=capacidad):
                parejas = parejas + 1
                posibles.append([i,j])
            
            j = j + 1
        i = i + 1
    
    # SALIDA
    print('La cantidad de parejas encontradas es: ')
    print(parejas)
    print('Se puede combinar: ')
    print(posibles)
    

    resultado del algoritmo

    capacidad de equipo: 350
    personas en cola: 3
    Peso[ 1]:120
    Peso[ 2]:180
    Peso[ 3]:165
    La cantidad de parejas encontradas es: 
    3
    Se puede combinar: 
    [[1, 2], [1, 3], [2, 3]]
    >>> 
    capacidad de equipo: 300
    personas en cola: 3
    Peso[ 1]:120
    Peso[ 2]:180
    Peso[ 3]:165
    La cantidad de parejas encontradas es: 
    2
    Se puede combinar: 
    [[1, 2], [1, 3]]
    >>> 
    

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]
    ..


    Diagrama de Flujo: Mientras-Repita

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]
    ..


    Diagrama de Flujo: Repita-Hasta

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]


    ejercicios resueltos Python 1eva_iit2014_t3 pdf

  • s1Eva_IT2014_T1 Cuadrado de Cinco

    Ejercicio: 1Eva_IT2014_T1 Cuadrado de Cinco

    Propuesta de solución en Python

    Operación decena decena+1 añadir resultado
    252 2 2+1=3 2*3 = 6 625
    852 8 8+1=9 8*9 = 72 7225

    Para validar la operación con los múltiplos de 5 menores que 100, se usa un intervalo entre [5,m]. El intervalo inicia con el número 5

    El siguiente número ascendente terminado en cinco es el anterior sumando 10.

    La decena del número se obtiene como el cociente de la división para 10

    El número por añadir a la izquierda de 25 es es la multiplicación de:
    (decena)*](decena+1), que equivale a las centenas.

    Para revisar que se cumpla la operación en todo el intervalo [5,m] se usa una bandera "funciona".


    Algoritmo en Python

    # ICM00794-Fundamentos de Computación - FCNM-ESPOL
    # 1Eva_IT2014_T1 Cuadrado de Cinco
    # Tarea: validar que la unidad del número sea 5
    
    # INGRESO
    m = int(input('rango [5,m]: '))
    
    # PROCEDIMIENTO
    numero = 5 # inicial
    funciona = True # si funciona
    while (numero<=m and funciona==True):
        
        # terminados en 5 desde el 15
        numero = numero+10
    
        # algoritmo cuadrado de 5
        unidad = numero%10    #residuo
        decena = numero//10   #cociente
        a = decena*(decena + 1)
        propuesto = a*100 + 25
    
        # calcula cuadrado
        calculado = numero*numero
    
        #compara resultado
        if (calculado!=propuesto):
            funciona = False
    
    # SALIDA
    print ('Algoritmo funciona:',funciona)
    if (funciona==0):
        print(numero)
    

    resultado del algoritmo dentro del intervalo.

    rango [5,m]: 100
    Algoritmo funciona: True
    >>> 
    rango [5,m]: 1000
    Algoritmo funciona: True
    >>> 
    
  • s1Eva_IIT2014_T2 Triángulos aleatorios en rectángulo

    Ejercicios: 1Eva_IIT2014_T2 Triángulos aleatorios en rectángulo

    [ algoritmo ] [ diagrama flujo ]

    Para iniciar el ejercicio, se requiere la cantidad n de triángulos a generar y los límites del plano donde se generan [maxa,maxb] .

    Para cada triángulo se generan las coordenadas de los vértices (xi,yi), usando números aleatorios ajustados a los límites del plano.

        # puntos aleatorios
        x1 = int(rnd.random()*maxa) +0
        y1 = int(rnd.random()*maxb) +0
        
        x2 = int(rnd.random()*maxa) +0
        y2 = int(rnd.random()*maxb) +0
    
        x3 = int(rnd.random()*maxa) +0
        y3 = int(rnd.random()*maxb) +0
    

    Lo más importante para este ejercicio es determinar las distancias entre los vértices, pues con ellas se determina el tipo de triángulo, siguiento las reglas básicas de la geometría.

        # distancias entre puntos
        a = np.sqrt((x2-x1)**2 + (y2-y1)**2)
        b = np.sqrt((x3-x2)**2 + (y3-y2)**2)
        c = np.sqrt((x1-x3)**2 + (y1-y3)**2)
    

    Puede darse el caso que los puntos se encuentren en una sola línea en el plano, el caso se verifica al revisar si la suma de la longitud de dos lados es la longitud del tercer lado. Comprobar en todas las combinaciones ésta situación.

    [ algoritmo ] [ diagrama flujo ]
    ..


    Algoritmo en Python

    # ICM00794-Fundamentos de Computación - FCNM-ESPOL
    # 1Eva_IIT2014_T2 Triángulos aleatorios en rectángulo
    # Propuesta de solución: edelros@espol.edu.ec
    
    import numpy as np
    import random as rnd
    import matplotlib.pyplot as plt
    
    # INGRESO
    n = int(input(" cuántos triángulos: "))
    maxa = int(input(" rango lado a: "))
    maxb = int(input(" rango lado b: "))
    
    # PROCEDIMIENTO
    equilatero = 0
    isosceles  = 0
    escaleno   = 0
    colineal   = 0
    
    i = 1
    while (i<=n):
        
        # puntos aleatorios
        x1 = int(rnd.random()*maxa) +0
        y1 = int(rnd.random()*maxb) +0
        
        x2 = int(rnd.random()*maxa) +0
        y2 = int(rnd.random()*maxb) +0
    
        x3 = int(rnd.random()*maxa) +0
        y3 = int(rnd.random()*maxb) +0
    
        # distancias entre puntos
        a = np.sqrt((x2-x1)**2 + (y2-y1)**2)
        b = np.sqrt((x3-x2)**2 + (y3-y2)**2)
        c = np.sqrt((x1-x3)**2 + (y1-y3)**2)
    
        # realiza la gráfica de cada triángulo
        plt.plot([x1, x2], [y1, y2])
        plt.plot([x2, x3], [y2, y3])
        plt.plot([x1, x3], [y1, y3])
    
        # clasifica triángulos
        s1 = a + b
        s2 = b + c
        s3 = c + a
        if (s1==c or s2==a or s3==b):
            colineal = colineal + 1
        else:
            if (a==b and b==c):
                equilatero = equilatero+1
            else:
                if (a!=b and b!=c and c!=a):
                    escaleno = escaleno+1
                else:
                    isosceles = isosceles+1
        i=i+1
    
    # SALIDA
    print("equilateros: ")
    print(equilatero)
    print("escalenos: ")
    print(escaleno)
    print("isosceles: ")
    print(isosceles)
    print("colineales: ")
    print(colineal)
    
    # muestra la gráfica
    plt.show()
    

    Resultado del algoritmo

     cuántos triángulos: 100
     rango lado a: 10
     rango lado b: 10
    equilateros: 
    0
    escalenos: 
    90
    isosceles: 
    4
    colineales: 
    6
    >>>
     cuántos triángulos: 100
     rango lado a: 10
     rango lado b: 10
    equilateros: 
    0
    escalenos: 
    87
    isosceles: 
    6
    colineales: 
    7
    >>> 
    

    [ algoritmo ] [ diagrama flujo ]
    ..


    Diagrama de Flujo

    [ algoritmo ] [ diagrama flujo ]


    ejercicios resueltos Python 1eva_iit2014_t2 pdf

  • s1Eva_IIT2014_T1 Verificar si a y b son Números amigos

    Ejercicios: 1Eva_IIT2014_T1 Números amigos

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]

    equipo01Dos números enteros positivos a y b son amigos sí solo sí la suma de los divisores de a es igual al número b, y la suma de los divisores de b es igual al número a.

    Se divide el ejercicio en dos partes, primero la suma de divisores del número a.

    # suma de divisores para "a"
    atotal = 1
    i = 2
    while (i<a):
          r = a%i
          if (r==0):
              atotal = atotal + i
          i = i + 1
    

    El concepto se repite par la suma de divisores de b.

    El resultado se obtiene comparando las sumas de divisores

    if (atotal==b and btotal==a):
          namigos = 1
    else:
          namigos = 0

    Se muestran los resultados al final

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]
    ..


    Algoritmo en Python

    # ICM00794-Fundamentos de Computación - FCNM-ESPOL
    # 1Eva_IIT2014_T1 Números amigos
    # Propuesta de solucion: edelros@espol.edu.ec
    
    # INGRESO
    a = int(input("número a: "))
    b = int(input("número b: "))
    
    # PROCEDIMIENTO
    
    # suma de divisores para "a"
    atotal = 1
    i = 2
    while (i<a):
          r = a%i
          if (r==0):
              atotal = atotal + i
          i = i + 1
    
    # suma de divisores para "b"
    btotal = 1
    j = 2
    while (j<b):
          r = b%j
          if (r==0):
              btotal = btotal + j
          j = j + 1
    
    if (atotal==b and btotal==a):
          namigos = 1
    else:
          namigos = 0
    
    # SALIDA
    print('números amigos: ', namigos)
    

    resultado del algoritmo

    número a: 220
    número b: 284
    números amigos:  1
    >>> 
    número a: 221
    número b: 284
    números amigos:  0
    

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]
    ..


    Diagrama de Flujo: Mientras-Repita


    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]
    ..


    Diagrama de Flujo: Repita-Hasta

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]

    ejercicios resueltos Python 1eva_iit2014_t1 pdf

  • s1Eva_IT2013_T4 Tabular atención al cliente

    Ejercicio: 1Eva_IT2013_T4 Tabular atención al cliente

    Para el ejercicio por simplicidad, en el bloque de ingreso se tabula también la "evaluación" del cliente para el servicio en un arreglo.

    Recuerde repasar el algoritmo del mayor


    Algoritmo en Python

    # ICM00794-Fundamentos de Computación - FCNM-ESPOL
    # 1Eva_IT2013_T4 Tabular atención al cliente
    # Tarea: literal c)
    #  calcular promedio dentro de procedimiento
    #  mostrar clientes con atencion menor al promedio en SALIDA
    import numpy as np
    
    # INGRESO
    n = int(input('cuantos clientes: '))
    atencion = np.zeros(n+1, dtype=int)
    cuenta   = np.zeros(6, dtype=int) # de 0 a 5
    cliente  = 1
    while not(cliente>n):
        pregunta = 'CLIENTE '+str(cliente)+' evalue: '
        nota = int(input(pregunta))
        
        if (nota>=1 and nota<n):
            atencion[cliente] = nota
            cuenta[nota] = cuenta[nota] + 1
        cliente = cliente + 1
    
    # Algoritmo Mayor
    mayor = 1  
    nota  = 2 
    while not(nota>5):
        if (cuenta[nota]>cuenta[mayor]):
            mayor = nota
        nota = nota + 1
        
    # SALIDA
    print('las evaluaciones fueron: ')
    print(cuenta)
    print('mayor: ',mayor)
    print('evaluacion [mayor]: ',cuenta[mayor])
    

    resultado esperado:

    cuantos clientes: 5
    CLIENTE 1 evalue: 1
    CLIENTE 2 evalue: 1
    CLIENTE 3 evalue: 1
    CLIENTE 4 evalue: 2
    CLIENTE 5 evalue: 2
    las evaluaciones fueron: 
    [0 3 2 0 0 0]
    mayor:  1
    evaluacion [mayor]:  3
    >>> 
    

    Tarea: literal c,  calcular promedio y seleccionar clientes que presentaron evaluación menor al promedio

  • s1Eva_IT2013_T1 Primos gemelos

    Ejercicio: 1Eva_IT2013_T1 Primos gemelos

    Para facilitar el ejercicio, pues no se dispone de una lista de números primos, se inicia generando usa secuencia ordenada de números naturales a partir del 2 hasta el número n donde se desea realizar la observación.

    # PROCEDIMIENTO
    # intervalo de búsqueda de números primos
    secuencia = np.arange(2,n+1,1)
    tamano = len(secuencia)
    
    # supone que todos son primos
    cumple = np.ones(tamano, dtype=int)

    Se simplifica el procedimiento de generar la secuencia usando la función de Numpy para generar un rango entre un intervalo [a,b) y dando el incremento: np.arange(a,b,incremento). Siendo un lado del intervalo no incluyente, pues se define con paréntesis, se añade el límite usando n+1.

    Sobre la secuencia, se usa un algoritmo de búsqueda de números primos realizado en clase para obtener un vector que tenga solo números primos. Otro ejemplo como repaso, puede revisar el ejercicio de la Criba de Eratóstenes.

    La búsqueda de primos gemelos consiste en comparar dos números consecutivo del vector soloprimos. Si la diferencia entre ellos es 2, se encontraron los números buscados. La respuesta se puede dar por medio de un nuevo vector o lista, o semejante al ejercicio de la Criba de Eratóstenes se puede usar un arreglo de banderas.


    Algoritmo en Python

    # ICM00794-Fundamentos de Computación - FCNM-ESPOL
    # 1Eva_IT2013_T1 Primos gemelos
    import numpy as np
    
    # INGRESO
    n = int(input('límite n: '))
    
    # PROCEDIMIENTO
    # intervalo de búsqueda de números primos
    secuencia = np.arange(2,n+1,1)
    tamano = len(secuencia)
    
    # supone que todos son primos
    cumple = np.ones(tamano, dtype=int)
    
    # revisa cada número de secuencia
    posicion = 0
    while (posicion<tamano):
        n = secuencia[posicion]
        
        # PROCEDIMIENTO esprimo 
        esprimo = 1
        divisor = 2
        while not(divisor>=n or esprimo==0):
            r = n%divisor
            if (r == 0):
                esprimo = 0
            divisor = divisor + 1
            
        cumple[posicion] = esprimo
        posicion = posicion + 1
    
    cuantos = np.sum(cumple)
    soloprimos = np.zeros(cuantos,dtype=int)
    
    # separa solo los primos
    posicion = 0
    i = 0
    while not(posicion>=tamano):
        if (cumple[posicion]==1):
            soloprimos[i] = secuencia[posicion]
            i = i + 1
        posicion = posicion + 1
    
    # SALIDA
    
    # BUSCA GEMELOS
    i = 0
    while not(i>=(cuantos-1)):
        sigue = i + 1
        diferencia = soloprimos[sigue] - soloprimos[i]
        if (diferencia==2):
            print('pareja gemelo: ')
            print(soloprimos[i],soloprimos[sigue])
        i = i + 1
        
    # revisando resultados
    print('secuencia: ', secuencia)
    print('cumple:    ', cumple)
    print('soloprimos:', soloprimos)
    

    resultado del algoritmo

    pareja gemelo: 
    3 5
    pareja gemelo: 
    5 7
    secuencia  [2 3 4 5 6 7 8 9]
    cumple:    [1 1 0 1 0 1 0 0]
    soloprimos: [2 3 5 7]
    >>> 
    
  • s1Eva_IIT2012_T2 Número camiseta equipo

    Ejercicio: 1Eva_IIT2012_T2 Número camiseta equipo

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]

    Para el bloque de ingreso usar tres variables: día, mes y año.

    # INGRESO
    dia  = int(input('dia: '))
    mes  = int(input('mes: '))
    anio = int(input('anio: '))
    

    Primero realice la suma de los componentes de la fecha para obtener el número de trabajo n.

    n = dia + mes + anio

    Se separan los dígitos de n usando el residuo y cociente, acumulando los dígitos en s, repitiendo la operación hasta que no queden más dígitos que separar.

        s = 0
        while (n>0):
            r = n%10
            n = n//10
            s = s + r

    Si el resultado de s tiene más de un dígito, se actualiza el valor de n con s y se repite el proceso anterior para acumular dígitos hasta obtener un resultado de un dígito. Se muestra el resultado “s”.

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]
    ..


    Algoritmo en Python

    # ICM00794-Fundamentos de Computación - FCNM-ESPOL
    # 1Eva_IIT2012_T2 Número camiseta equipo
    # Propuesta: edelros@espol.edu.ec
    
    # INGRESO
    dia  = int(input('dia: '))
    mes  = int(input('mes: '))
    anio = int(input('anio: '))
    
    # PROCEDIMIENTO
    n = dia + mes + anio
    while (n>=10):
        s = 0
        while (n>0):
            r = n%10
            n = n//10
            s = s + r
        n = s
    
    # SALIDA
    print('número buscado es: ')
    print(n)
    

    Resultado del Algoritmo

    dia: 12
    mes: 8
    anio: 2000
    número buscado es: 
    4
    >>> 
    dia: 25
    mes: 12
    anio: 2000
    número buscado es: 
    3
    >>> 
    

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]
    ..


    Diagrama de Flujo: mientras-repita

    numero camiseta equipo diagrama de flujo

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]
    ..


    Diagrama de Flujo: repita-hasta

    diagrama de flujo repita-hasta

    [ algoritmo ] diagrama flujo: [ mientras-repita ] [ repita-hasta ]


    Propuesta de solución con diagrama de flujo, Python y otra versión con Matlab

    ejercicios resueltos Python 1eva_iit2012_t2 pdf

    ejercicios resueltos Matlab 1eva_iit2012_t2 pdf