mirror of
https://github.com/TheAlgorithms/C-Plus-Plus.git
synced 2026-03-21 12:23:13 +08:00
297 lines
14 KiB
HTML
297 lines
14 KiB
HTML
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
|
<head>
|
|
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
<meta name="generator" content="Doxygen 1.8.18"/>
|
|
<meta name="viewport" content="width=device-width, initial-scale=1"/>
|
|
<title>My Project: non_recursive_merge_sort.cpp File Reference</title>
|
|
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="jquery.js"></script>
|
|
<script type="text/javascript" src="dynsections.js"></script>
|
|
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
<script type="text/javascript" src="search/search.js"></script>
|
|
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
</head>
|
|
<body>
|
|
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
<div id="titlearea">
|
|
<table cellspacing="0" cellpadding="0">
|
|
<tbody>
|
|
<tr style="height: 56px;">
|
|
<td id="projectalign" style="padding-left: 0.5em;">
|
|
<div id="projectname">My Project
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<!-- end header part -->
|
|
<!-- Generated by Doxygen 1.8.18 -->
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
var searchBox = new SearchBox("searchBox", "search",false,'Search');
|
|
/* @license-end */
|
|
</script>
|
|
<script type="text/javascript" src="menudata.js"></script>
|
|
<script type="text/javascript" src="menu.js"></script>
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
$(function() {
|
|
initMenu('',true,false,'search.php','Search');
|
|
$(document).ready(function() { init_search(); });
|
|
});
|
|
/* @license-end */</script>
|
|
<div id="main-nav"></div>
|
|
<!-- window showing the filter options -->
|
|
<div id="MSearchSelectWindow"
|
|
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
</div>
|
|
|
|
<!-- iframe showing the search results (closed by default) -->
|
|
<div id="MSearchResultsWindow">
|
|
<iframe src="javascript:void(0)" frameborder="0"
|
|
name="MSearchResults" id="MSearchResults">
|
|
</iframe>
|
|
</div>
|
|
|
|
</div><!-- top -->
|
|
<div class="header">
|
|
<div class="summary">
|
|
<a href="#func-members">Functions</a> </div>
|
|
<div class="headertitle">
|
|
<div class="title">non_recursive_merge_sort.cpp File Reference</div> </div>
|
|
</div><!--header-->
|
|
<div class="contents">
|
|
<div class="textblock"><code>#include <cstddef></code><br />
|
|
<code>#include <utility></code><br />
|
|
<code>#include <iostream></code><br />
|
|
</div><div class="textblock"><div class="dynheader">
|
|
Include dependency graph for non_recursive_merge_sort.cpp:</div>
|
|
<div class="dyncontent">
|
|
<div class="center"><img src="non__recursive__merge__sort_8cpp__incl.png" border="0" usemap="#non__recursive__merge__sort_8cpp" alt=""/></div>
|
|
<map name="non__recursive__merge__sort_8cpp" id="non__recursive__merge__sort_8cpp">
|
|
<area shape="rect" title=" " alt="" coords="47,5,194,47"/>
|
|
<area shape="rect" title=" " alt="" coords="5,95,71,121"/>
|
|
<area shape="rect" title=" " alt="" coords="95,95,147,121"/>
|
|
<area shape="rect" title=" " alt="" coords="171,95,243,121"/>
|
|
</map>
|
|
</div>
|
|
</div><table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a>
|
|
Functions</h2></td></tr>
|
|
<tr class="memitem:aee1ab42c3a838aa040efd8e784f4a9ab"><td class="memTemplParams" colspan="2">template<class Iterator > </td></tr>
|
|
<tr class="memitem:aee1ab42c3a838aa040efd8e784f4a9ab"><td class="memTemplItemLeft" align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="non__recursive__merge__sort_8cpp.html#aee1ab42c3a838aa040efd8e784f4a9ab">merge</a> (Iterator l, Iterator r, const Iterator e, char b[])</td></tr>
|
|
<tr class="memdesc:aee1ab42c3a838aa040efd8e784f4a9ab"><td class="mdescLeft"> </td><td class="mdescRight">merges 2 sorted adjacent segments into a larger sorted segment <a href="non__recursive__merge__sort_8cpp.html#aee1ab42c3a838aa040efd8e784f4a9ab">More...</a><br /></td></tr>
|
|
<tr class="separator:aee1ab42c3a838aa040efd8e784f4a9ab"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a797be8541ef8748f02c5ef74b3523e4b"><td class="memTemplParams" colspan="2">template<class Iterator > </td></tr>
|
|
<tr class="memitem:a797be8541ef8748f02c5ef74b3523e4b"><td class="memTemplItemLeft" align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="non__recursive__merge__sort_8cpp.html#a797be8541ef8748f02c5ef74b3523e4b">non_recursive_merge_sort</a> (const Iterator first, const Iterator last, const size_t n)</td></tr>
|
|
<tr class="memdesc:a797be8541ef8748f02c5ef74b3523e4b"><td class="mdescLeft"> </td><td class="mdescRight">bottom-up merge sort which sorts elements in a non-decreasing order <a href="non__recursive__merge__sort_8cpp.html#a797be8541ef8748f02c5ef74b3523e4b">More...</a><br /></td></tr>
|
|
<tr class="separator:a797be8541ef8748f02c5ef74b3523e4b"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:af9efd27abc01f33180960004cd0009d9"><td class="memTemplParams" colspan="2">template<class Iterator > </td></tr>
|
|
<tr class="memitem:af9efd27abc01f33180960004cd0009d9"><td class="memTemplItemLeft" align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="non__recursive__merge__sort_8cpp.html#af9efd27abc01f33180960004cd0009d9">non_recursive_merge_sort</a> (const Iterator first, const size_t n)</td></tr>
|
|
<tr class="memdesc:af9efd27abc01f33180960004cd0009d9"><td class="mdescLeft"> </td><td class="mdescRight">bottom-up merge sort which sorts elements in a non-decreasing order <a href="non__recursive__merge__sort_8cpp.html#af9efd27abc01f33180960004cd0009d9">More...</a><br /></td></tr>
|
|
<tr class="separator:af9efd27abc01f33180960004cd0009d9"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a53daee11a3b0d34cf186b161edb77a5e"><td class="memTemplParams" colspan="2">template<class Iterator > </td></tr>
|
|
<tr class="memitem:a53daee11a3b0d34cf186b161edb77a5e"><td class="memTemplItemLeft" align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="non__recursive__merge__sort_8cpp.html#a53daee11a3b0d34cf186b161edb77a5e">non_recursive_merge_sort</a> (const Iterator first, const Iterator last)</td></tr>
|
|
<tr class="memdesc:a53daee11a3b0d34cf186b161edb77a5e"><td class="mdescLeft"> </td><td class="mdescRight">bottom-up merge sort which sorts elements in a non-decreasing order <a href="non__recursive__merge__sort_8cpp.html#a53daee11a3b0d34cf186b161edb77a5e">More...</a><br /></td></tr>
|
|
<tr class="separator:a53daee11a3b0d34cf186b161edb77a5e"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a3c04138a5bfe5d72780bb7e82a18e627"><td class="memItemLeft" align="right" valign="top"><a id="a3c04138a5bfe5d72780bb7e82a18e627"></a>
|
|
int </td><td class="memItemRight" valign="bottom"><b>main</b> (int argc, char **argv)</td></tr>
|
|
<tr class="separator:a3c04138a5bfe5d72780bb7e82a18e627"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table>
|
|
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
|
|
<div class="textblock"><p>Copyright 2020 </p><dl class="section author"><dt>Author</dt><dd>Albirair</dd></dl>
|
|
<p>A generic implementation of non-recursive merge sort. </p>
|
|
</div><h2 class="groupheader">Function Documentation</h2>
|
|
<a id="aee1ab42c3a838aa040efd8e784f4a9ab"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#aee1ab42c3a838aa040efd8e784f4a9ab">◆ </a></span>merge()</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<class Iterator > </div>
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void merge </td>
|
|
<td>(</td>
|
|
<td class="paramtype">Iterator </td>
|
|
<td class="paramname"><em>l</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">Iterator </td>
|
|
<td class="paramname"><em>r</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const Iterator </td>
|
|
<td class="paramname"><em>e</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">char </td>
|
|
<td class="paramname"><em>b</em>[] </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>merges 2 sorted adjacent segments into a larger sorted segment </p>
|
|
<p>best-case = worst-case = O(n) </p><dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">l</td><td>points to the left part </td></tr>
|
|
<tr><td class="paramname">r</td><td>points to the right part, end of left part </td></tr>
|
|
<tr><td class="paramname">e</td><td>points to end of right part </td></tr>
|
|
<tr><td class="paramname">b</td><td>points at the buffer </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a53daee11a3b0d34cf186b161edb77a5e"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a53daee11a3b0d34cf186b161edb77a5e">◆ </a></span>non_recursive_merge_sort() <span class="overload">[1/3]</span></h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<class Iterator > </div>
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void non_recursive_merge_sort </td>
|
|
<td>(</td>
|
|
<td class="paramtype">const Iterator </td>
|
|
<td class="paramname"><em>first</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const Iterator </td>
|
|
<td class="paramname"><em>last</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>bottom-up merge sort which sorts elements in a non-decreasing order </p>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">first</td><td>points to the first element </td></tr>
|
|
<tr><td class="paramname">last</td><td>points to 1-step past the last element </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a797be8541ef8748f02c5ef74b3523e4b"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a797be8541ef8748f02c5ef74b3523e4b">◆ </a></span>non_recursive_merge_sort() <span class="overload">[2/3]</span></h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<class Iterator > </div>
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void non_recursive_merge_sort </td>
|
|
<td>(</td>
|
|
<td class="paramtype">const Iterator </td>
|
|
<td class="paramname"><em>first</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const Iterator </td>
|
|
<td class="paramname"><em>last</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const size_t </td>
|
|
<td class="paramname"><em>n</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>bottom-up merge sort which sorts elements in a non-decreasing order </p>
|
|
<p>sorts elements non-recursively by breaking them into small segments, merging adjacent segments into larger sorted segments, then increasing the sizes of segments by factors of 2 and repeating the same process. best-case = worst-case = O(n log(n)) </p><dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">first</td><td>points to the first element </td></tr>
|
|
<tr><td class="paramname">last</td><td>points to 1-step past the last element </td></tr>
|
|
<tr><td class="paramname">n</td><td>the number of elements </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="af9efd27abc01f33180960004cd0009d9"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#af9efd27abc01f33180960004cd0009d9">◆ </a></span>non_recursive_merge_sort() <span class="overload">[3/3]</span></h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<class Iterator > </div>
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void non_recursive_merge_sort </td>
|
|
<td>(</td>
|
|
<td class="paramtype">const Iterator </td>
|
|
<td class="paramname"><em>first</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const size_t </td>
|
|
<td class="paramname"><em>n</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>bottom-up merge sort which sorts elements in a non-decreasing order </p>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">first</td><td>points to the first element </td></tr>
|
|
<tr><td class="paramname">n</td><td>the number of elements </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
|
|
</div>
|
|
</div>
|
|
</div><!-- contents -->
|
|
<!-- start footer part -->
|
|
<hr class="footer"/><address class="footer"><small>
|
|
Generated by  <a href="http://www.doxygen.org/index.html">
|
|
<img class="footer" src="doxygen.png" alt="doxygen"/>
|
|
</a> 1.8.18
|
|
</small></address>
|
|
</body>
|
|
</html>
|