Manchas2k4 / tc1031-act13-integral-basic-concept-template-ad2023

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Tec de Monterrey

Act 1.3 - Actividad Integral de Conceptos Básicos y Algoritmos Fundamentales (Evidencia Competencia)

¿Qué tengo que hacer?

En este repositorio encontrarás los archivos de entrada, así como las salidas esperadas que podrás usar para probar tu implementación. También encontrarás un archivo "main.cpp". Ahí deberás implementar tu solución. En el archivo deberás colocar en la parte superior, en comentarios, tus datos. Por ejemplo:

// =========================================================
// File: main.cpp
// Author: Edward Elric - A00123456
// Date: 01/01/2021
// =========================================================

De manera individual, desarrolla la solución del siguiente problema:

Una medida de "desorden" en una secuencia es el número de pares de entradas que están desordenadas entre sí. Por ejemplo, en la secuencia de letras “DAABEC”, esta medida es 5, ya que D es mayor que cuatro letras a su derecha y E es mayor que una letra a su derecha. Esta medida se llama el número de inversiones en la secuencia. La secuencia "AACEDGG" tiene solo una inversión (E y D), está casi ordenada, mientras que la secuencia "ZWQM" tiene 6 inversiones (es tan desordenada como puede ser, exactamente lo contrario de ordenada).

Eres responsable de catalogar una secuencia de cadenas de ADN (secuencias que contienen solo las cuatro letras A, C, G y T). Sin embargo, desea catalogarlos, no en orden alfabético, sino en orden de "clasificación", de "más ordenados" a "menos ordenados". Todas las cuerdas son de la misma longitud.

Entrada

La primera línea contiene dos números enteros: un número entero positivo n (0 < n <= 50) que da la longitud de las cadenas; y un entero positivo m (0 < m <= 100) dando el número de cadenas. Estos son seguidos por m líneas, cada una de las cuales contiene una cadena de longitud n.

Salida

Genera la lista de cadenas de entrada, ordenadas de "más ordenadas" a "menos ordenadas". Si dos o más cadenas están igualmente ordenadas, enumérelas en el mismo orden en que están en el archivo de entrada.

Ejemplo de entrada

10 6
AACATGAAGG
TTTTGGCCAA
TTTGGCCAAA
GATCAGATTT
CCCGGGGGGA
ATCGATGCAT

Ejemplo de salida

CCCGGGGGGA
AACATGAAGG
GATCAGATTT
ATCGATGCAT
TTTTGGCCAA
TTTGGCCAAA

Para probar tu implementación, compila tu programa con el comando:

g++ -std=c++11 main.cpp -o app

Posteriormente, prueba con cada uno de los archivos de entrada de prueba que encontrarás en este repositorio (input1.txt, input2.txt, input3.txt, input4.txt). Los resultados que debes obtener se encuentran en los archivos llamados output1.txt, output1.txt, output1.txt y output1.txt. Para realizar las pruebas, puedes usar las siguientes líneas de código. Por ejemplo, si queremos probar con el archivo de prueba "input1.txt".

./app < input1.txt > mysolution1.txt
diff mysolution1.txt output1.txt

Si el segundo comando no tenga ninguna salida, sabrás que los resultados que obtuviste son los esperados.

Por último, realiza una investigación y reflexión en forma individual de la importancia y eficiencia del uso de los diferentes algoritmos de ordenamiento y búsqueda en una situación problema de esta naturaleza, generando un documento llamado "ReflexAct1.3.pdf"

¿Bajo qué criterios se evalúa mi evidencia?

  • 80% - Para cada una de las funcionalidades se evaluará:

    • Excelente (80%) - pasa correctamente todos los casos de prueba.
    • Muy Bien (60%) - pasa correctamente el 75% de los casos de prueba.
    • Bien (40%) - pasa correctamente el 50% de los casos de prueba.
    • Insuficiente (20%) - pasa correctamente menos del 50% de los casos de prueba.
  • 10% - El código deberá seguir los lineamientos estipulados en el estándar de codificación: liga_estándar_codificación

  • 10% - Se respetenan los nombres de las funciones en la aplicación.

¿Dónde la entrego?

Esta actividad forma parte tanto de tu calificación final del curso, así como del portafolio de evidencias de las competencias a desarrollar del curso, por lo que se te pide que en forma individual:

  • Realices una entrega de los archivos correspondientes de los algoritmos de ordenamiento y búsqueda, en la sección correspondiente dentro de esta plataforma, así como el documento de reflexión individual (ReflexAct1.3.pdf).
  • Generes una carpeta en forma personal llamada TC1031(Portafolio_Final) que servirá como preparación para la entrega del portafolio de competencias que se realizará al final del curso, esta carpeta debe contener 5 carpetas:
    • Act1.3 - coloca aquí tus archivos que solucionaron la actividad 1.3 así como el documento de reflexión individual (ReflexAct1.3.pdf).
    • Act2.3
    • Act3.4
    • Act4.3
    • Act5.2

About


Languages

Language:C++ 100.0%