Compare commits

..

No commits in common. "master" and "1.0.1" have entirely different histories.

2 changed files with 20 additions and 22 deletions

View File

@ -23,7 +23,7 @@
} }
\usepackage{hyperref} \usepackage{hyperref}
\hypersetup{colorlinks=true,allcolors=black,pdftitle={Tarea 1: Ordenamiento}} \hypersetup{colorlinks=true,allcolors=black,bookmarks,pdftitle={Tarea 1: Ordenamiento}}
\usepackage{hypcap} \usepackage{hypcap}
\pretitle{% \pretitle{%
@ -37,7 +37,6 @@
\posttitle{\end{center}} \posttitle{\end{center}}
\begin{document} \begin{document}
\hypersetup{pageanchor=false}
\clearpage\maketitle \clearpage\maketitle
\thispagestyle{empty} \thispagestyle{empty}
@ -65,7 +64,6 @@ Xavier Canales
\tableofcontents \tableofcontents
\newpage \newpage
\hypersetup{pageanchor=true}
\pagenumbering{arabic} \pagenumbering{arabic}
\section{Pseudo código} \section{Pseudo código}
\subsection{Merge Sort} \subsection{Merge Sort}
@ -97,63 +95,63 @@ Xavier Canales
\subsection{Análisis temporal} \subsection{Análisis temporal}
\subsubsection{Merge Sort} \subsubsection{Merge Sort}
\underline{Caso Promedio:} $ \Theta(n log n)) $ \\ \underline{Caso Promedio:} $ \Theta(n log n)) $ \\
El caso promedio de merge sort es similar a peor caso. \bigskip El caso promedio de merge sort es similar a peor caso. \\
\underline{Peor Caso:} $ O(n log n) $ \\ \underline{Peor Caso:} $ O(n log n) $ \\
En el peor de los casos, el merge sort hace aproximadamente un 39\% menos de comparaciones que el quick sort en su caso promedio. En términos de movimientos, la complejidad del peor de los casos de merge sort es $ O(n log n) $ la misma complejidad que el mejor de Quick sort, y el mejor de la clasificación de merge sort toma aproximadamente la mitad de las iteraciones que en el peor de los casos. \bigskip En el peor de los casos, el merge sort hace aproximadamente un 39\% menos de comparaciones que el quick sort en su caso promedio. En términos de movimientos, la complejidad del peor de los casos de merge sort es $ O(n log n) $ la misma complejidad que el mejor de Quick sort, y el mejor de la clasificación de merge sort toma aproximadamente la mitad de las iteraciones que en el peor de los casos. \\
\underline{Mejor Caso:} $ \Omega(n log n)$ \\ \underline{Mejor Caso:} $ \Omega(n log n)$ \\
En el caso mejor de merge sort, el merge sort funciona mejor cuando los datos son secuencial. \bigskip En el caso mejor de merge sort, el merge sort funciona mejor cuando los datos son secuencial. \\
\subsubsection{Quick Sort} \subsubsection{Quick Sort}
\underline{Caso Promedio:} $ \Theta(n(log n)) $ \\ \underline{Caso Promedio:} $ \Theta(n(log n)) $ \\
El tiempo de ejecución que tendrá el algoritmo dependerá de como se realice la partición de el arreglo entrada, es decir, depende de la selección del pivote. \bigskip El tiempo de ejecución que tendrá el algoritmo dependerá de como se realice la partición de el arreglo entrada, es decir, depende de la selección del pivote. \\
\underline{Peor Caso:} $ O(n^2) $ \\ \underline{Peor Caso:} $ O(n^2) $ \\
El peor de los casos para el quick sort resultará cuando la elección del pivote sea el valor más pequeño del arreglo o el más grande de este mismo. \bigskip El peor de los casos para el quick sort resultará cuando la elección del pivote sea el valor más pequeño del arreglo o el más grande de este mismo. \\
\underline{Mejor Caso:} $ \Omega(n log(n)) $ \\ \underline{Mejor Caso:} $ \Omega(n log(n)) $ \\
Para obtener el mejor caso posible será cuando el pivote se encuentre exactamente al medio del arreglo, porque lo dividirá en dos obteniendo n/2 elementos en ambas divisiones del arreglo. \bigskip Para obtener el mejor caso posible será cuando el pivote se encuentre exactamente al medio del arreglo, porque lo dividirá en dos obteniendo n/2 elementos en ambas divisiones del arreglo. \\
\subsubsection{Bubble Sort} \subsubsection{Bubble Sort}
\underline{Caso Promedio:} $ \Theta(n^2)) $ \\ \underline{Caso Promedio:} $ \Theta(n^2)) $ \\
El caso promedio compara la complejidad temporal con el peor caso, donde n es el numero de valores a ordenar, esto es producto de la forma en la cual \textit{bubble} transporta los valores dentro de su ordenamiento. \bigskip El caso promedio compara la complejidad temporal con el peor caso, donde n es el numero de valores a ordenar, esto es producto de la forma en la cual \textit{bubble} transporta los valores dentro de su ordenamiento. \\
\underline{Peor Caso:} $ O(n^2) $ \\ \underline{Peor Caso:} $ O(n^2) $ \\
En el peor caso el arreglo a ordenar va a estar ordenado en forma descendente previamente. \bigskip En el peor caso el arreglo a ordenar va a estar ordenado en forma descendente previamente. \\
\underline{Mejor Caso:} $ \Omega(n)$ \\ \underline{Mejor Caso:} $ \Omega(n)$ \\
El mejor caso para el bubble sort será cuando el arreglo de entrada venga previamente ordenado de menor a mayor. \bigskip El mejor caso para el bubble sort será cuando el arreglo de entrada venga previamente ordenado de menor a mayor. \\
\subsubsection{Bitonic Sort} \subsubsection{Bitonic Sort}
\underline{Caso Promedio:} $\Theta(log^2(n))$ \\ \underline{Caso Promedio:} $\Theta(log^2(n))$ \\
El ordenamiento bitonico responde igual a todos los casos porque siempre antes de empezar a ordenarlos realiza las mismas comparaciones para dejarlos en la secuencia bitonica. \bigskip El ordenamiento bitonico responde igual a todos los casos porque siempre antes de empezar a ordenarlos realiza las mismas comparaciones para dejarlos en la secuencia bitonica. \\
\underline{Peor Caso:} $ O(log^2(n)) $ \\ \underline{Peor Caso:} $ O(log^2(n)) $ \\
Su peor caso es igual que su caso promedio. \bigskip Su peor caso es igual que su caso promedio. \\
\underline{Mejor Caso:} $ \Omega(log^2(n)) $ \\ \underline{Mejor Caso:} $ \Omega(log^2(n)) $ \\
Su mejor caso es igual que su caso promedio. \bigskip Su mejor caso es igual que su caso promedio. \\
\subsubsection{Counting Sort} \subsubsection{Counting Sort}
\underline{Caso Promedio:} $ \Theta(\frac{n^2}{2}) $ \\ \underline{Caso Promedio:} $ \Theta(\frac{n^2}{2}) $ \\
La complejidad total es igual para todos los casos, porque el algoritmo usa sólo ciclos simples, sin recursividad o sub-funciones, va directamente al análisis. \bigskip La complejidad total es igual para todos los casos, porque el algoritmo usa sólo ciclos simples, sin recursividad o sub-funciones, va directamente al análisis. \\
\underline{Peor Caso:} $ O(\frac{n^2}{2}) $ \\ \underline{Peor Caso:} $ O(\frac{n^2}{2}) $ \\
Su peor caso es igual a su caso promedio. \bigskip Su peor caso es igual a su caso promedio. \\
\underline{Mejor Caso:} $ \Omega(\frac{n^2}{2}) $ \\ \underline{Mejor Caso:} $ \Omega(\frac{n^2}{2}) $ \\
Su mejor caso es igual a su caso promedio. \bigskip Su mejor caso es igual a su caso promedio. \\
\subsubsection{Selection Sort} \subsubsection{Selection Sort}
\underline{Caso Promedio:} $ \Theta(n^2) $ \\ \underline{Caso Promedio:} $ \Theta(n^2) $ \\
El ordenamiento por selección no es un algoritmo de ordenamiento adaptable, realiza el mismo numero de comparaciones de elementos en el mejor caso, el caso promedio y el peor de los casos, esto se debe a que no utiliza el orden existente de las entradas del arreglo para ordenar. \bigskip El ordenamiento por selección no es un algoritmo de ordenamiento adaptable, realiza el mismo numero de comparaciones de elementos en el mejor caso, el caso promedio y el peor de los casos, esto se debe a que no utiliza el orden existente de las entradas del arreglo para ordenar. \\
\underline{Peor Caso:} $ O(n^2) $ \\ \underline{Peor Caso:} $ O(n^2) $ \\
Su peor caso es igual a su caso promedio. \bigskip Su peor caso es igual a su caso promedio. \\
\underline{Mejor Caso:} $ \Omega(n^2) $ \\ \underline{Mejor Caso:} $ \Omega(n^2) $ \\
Su mejor caso es igual a su caso promedio. \bigskip Su mejor caso es igual a su caso promedio. \\
\newpage \newpage
\subsection{Datos} \subsection{Datos}

View File

@ -28,7 +28,7 @@
#include "selection_sort.h" #include "selection_sort.h"
#include "merge_sort.h" #include "merge_sort.h"
#define SORT_VERSION "1.0.2" #define SORT_VERSION "1.0.1"
/** /**
* El array desordenado * El array desordenado