\documentclass[10pt,a4paper]{article} % Packages \usepackage{fancyhdr} % For header and footer \usepackage{multicol} % Allows multicols in tables \usepackage{tabularx} % Intelligent column widths \usepackage{tabulary} % Used in header and footer \usepackage{hhline} % Border under tables \usepackage{graphicx} % For images \usepackage{xcolor} % For hex colours %\usepackage[utf8x]{inputenc} % For unicode character support \usepackage[T1]{fontenc} % Without this we get weird character replacements \usepackage{colortbl} % For coloured tables \usepackage{setspace} % For line height \usepackage{lastpage} % Needed for total page number \usepackage{seqsplit} % Splits long words. %\usepackage{opensans} % Can't make this work so far. Shame. Would be lovely. \usepackage[normalem]{ulem} % For underlining links % Most of the following are not required for the majority % of cheat sheets but are needed for some symbol support. \usepackage{amsmath} % Symbols \usepackage{MnSymbol} % Symbols \usepackage{wasysym} % Symbols %\usepackage[english,german,french,spanish,italian]{babel} % Languages % Document Info \author{minhkhanh29} \pdfinfo{ /Title (data-structures-and-algorithms-with-c.pdf) /Creator (Cheatography) /Author (minhkhanh29) /Subject (Data Structures and Algorithms with C Cheat Sheet) } % Lengths and widths \addtolength{\textwidth}{6cm} \addtolength{\textheight}{-1cm} \addtolength{\hoffset}{-3cm} \addtolength{\voffset}{-2cm} \setlength{\tabcolsep}{0.2cm} % Space between columns \setlength{\headsep}{-12pt} % Reduce space between header and content \setlength{\headheight}{85pt} % If less, LaTeX automatically increases it \renewcommand{\footrulewidth}{0pt} % Remove footer line \renewcommand{\headrulewidth}{0pt} % Remove header line \renewcommand{\seqinsert}{\ifmmode\allowbreak\else\-\fi} % Hyphens in seqsplit % This two commands together give roughly % the right line height in the tables \renewcommand{\arraystretch}{1.3} \onehalfspacing % Commands \newcommand{\SetRowColor}[1]{\noalign{\gdef\RowColorName{#1}}\rowcolor{\RowColorName}} % Shortcut for row colour \newcommand{\mymulticolumn}[3]{\multicolumn{#1}{>{\columncolor{\RowColorName}}#2}{#3}} % For coloured multi-cols \newcolumntype{x}[1]{>{\raggedright}p{#1}} % New column types for ragged-right paragraph columns \newcommand{\tn}{\tabularnewline} % Required as custom column type in use % Font and Colours \definecolor{HeadBackground}{HTML}{333333} \definecolor{FootBackground}{HTML}{666666} \definecolor{TextColor}{HTML}{333333} \definecolor{DarkBackground}{HTML}{5BA32A} \definecolor{LightBackground}{HTML}{F4F9F1} \renewcommand{\familydefault}{\sfdefault} \color{TextColor} % Header and Footer \pagestyle{fancy} \fancyhead{} % Set header to blank \fancyfoot{} % Set footer to blank \fancyhead[L]{ \noindent \begin{multicols}{3} \begin{tabulary}{5.8cm}{C} \SetRowColor{DarkBackground} \vspace{-7pt} {\parbox{\dimexpr\textwidth-2\fboxsep\relax}{\noindent \hspace*{-6pt}\includegraphics[width=5.8cm]{/web/www.cheatography.com/public/images/cheatography_logo.pdf}} } \end{tabulary} \columnbreak \begin{tabulary}{11cm}{L} \vspace{-2pt}\large{\bf{\textcolor{DarkBackground}{\textrm{Data Structures and Algorithms with C Cheat Sheet}}}} \\ \normalsize{by \textcolor{DarkBackground}{minhkhanh29} via \textcolor{DarkBackground}{\uline{cheatography.com/172691/cs/36297/}}} \end{tabulary} \end{multicols}} \fancyfoot[L]{ \footnotesize \noindent \begin{multicols}{3} \begin{tabulary}{5.8cm}{LL} \SetRowColor{FootBackground} \mymulticolumn{2}{p{5.377cm}}{\bf\textcolor{white}{Cheatographer}} \\ \vspace{-2pt}minhkhanh29 \\ \uline{cheatography.com/minhkhanh29} \\ \end{tabulary} \vfill \columnbreak \begin{tabulary}{5.8cm}{L} \SetRowColor{FootBackground} \mymulticolumn{1}{p{5.377cm}}{\bf\textcolor{white}{Cheat Sheet}} \\ \vspace{-2pt}Not Yet Published.\\ Updated 28th December, 2022.\\ Page {\thepage} of \pageref{LastPage}. \end{tabulary} \vfill \columnbreak \begin{tabulary}{5.8cm}{L} \SetRowColor{FootBackground} \mymulticolumn{1}{p{5.377cm}}{\bf\textcolor{white}{Sponsor}} \\ \SetRowColor{white} \vspace{-5pt} %\includegraphics[width=48px,height=48px]{dave.jpeg} Measure your website readability!\\ www.readability-score.com \end{tabulary} \end{multicols}} \begin{document} \raggedright \raggedcolumns % Set font size to small. Switch to any value % from this page to resize cheat sheet text: % www.emerson.emory.edu/services/latex/latex_169.html \footnotesize % Small font. \begin{multicols*}{4} \begin{tabularx}{3.833cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{3.833cm}}{\bf\textcolor{white}{Searching Algorithms}} \tn \SetRowColor{white} \mymulticolumn{1}{x{3.833cm}}{· Linear Search – Unsorted Input \newline % Row Count 1 (+ 1) · Linear Search – Sorted Input \newline % Row Count 2 (+ 1) · Binary Search (Sorted Input) \newline % Row Count 3 (+ 1) · String Search: Tries, Suffix Trees, Ternary Search. \newline % Row Count 5 (+ 2) · Hashing and Symbol Tables% Row Count 6 (+ 1) } \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{3.833cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{3.833cm}}{\bf\textcolor{white}{Linear Search – Unsorted Input}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{3.833cm}}{int linearSearchUnsorted(int arr{[}{]}, int size, int value) \newline \{ \newline int i = 0; \newline for(i = 0 ; i \textless{} size ; i++)\{ \newline if(value == arr{[}i{]}) return i; \newline \} \newline return -1; \newline \}} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \SetRowColor{LightBackground} \mymulticolumn{1}{x{3.833cm}}{{\bf{Time Complexity: O(n)}}. As we need to traverse the complete array in worst case. Worst case is when \newline your desired element is at the last position of the array. Here, 'n' is the size of the array. \newline {\bf{Space Complexity: O(1)}}. No extra memory is used to allocate the array.} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{3.833cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{3.833cm}}{\bf\textcolor{white}{Linear Search – Sorted}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{3.833cm}}{int linearSearchSorted(int arr{[}{]}, int size, int value) \newline \{ \newline int i = 0; \newline for(i = 0 ; i \textless{} size ; i++)\{ \newline if(value == arr{[}i{]}) return i; \newline else if(value \textless{} arr{[}i{]}) return -1; \newline \} \newline return -1; \newline \}} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \SetRowColor{LightBackground} \mymulticolumn{1}{x{3.833cm}}{{\bf{Time Complexity: O(n)}}. As we need to traverse the complete array in worst case. Worst case is when your desired element is at the last position of the sorted array. However, in the average case this \newline algorithm is more efficient even though the growth rate is same as unsorted. \newline {\bf{Space Complexity: O(1)}}. No extra memory is used to allocate the array.} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{3.833cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{3.833cm}}{\bf\textcolor{white}{Binary Search}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{3.833cm}}{/{\emph{ Binary Search Algorithm – Iterative Way }}/ \newline int Binarysearch(int arr{[}{]}, int size, int value) \newline \{ \newline int low = 0; \newline int high = size-1; \newline int mid; \newline while(low \textless{}= high)\{ \newline mid = low + (high-low)/2; /{\emph{ To avoid the overflow }}/ \newline if (arr{[}mid{]} == value) return mid; \newline else if (arr{[}mid{]} \textless{} value) low = mid + 1; \newline else high = mid - 1; \newline \} \newline return -1; \newline \}} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \SetRowColor{LightBackground} \mymulticolumn{1}{x{3.833cm}}{{\bf{Time Complexity: O(logn)}}. We always take half input and throwing out the other half. So the recurrencerelation for binary search is T(n) = T(n/2) + c. Using master theorem (divide and conquer), we get T(n) =O(logn) \newline {\bf{Space Complexity: O(1)}}} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} % That's all folks \end{multicols*} \end{document}