index.html 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=2">
  6. <meta name="theme-color" content="#222">
  7. <meta name="generator" content="Hexo 4.2.0">
  8. <link rel="apple-touch-icon" sizes="180x180" href="/images/apple-touch-icon-next.png">
  9. <link rel="icon" type="image/png" sizes="32x32" href="/images/favicon-32x32-next.png">
  10. <link rel="icon" type="image/png" sizes="16x16" href="/images/favicon-16x16-next.png">
  11. <link rel="mask-icon" href="/images/logo.svg" color="#222">
  12. <link rel="stylesheet" href="/css/main.css">
  13. <link rel="stylesheet" href="/lib/font-awesome/css/font-awesome.min.css">
  14. <link rel="stylesheet" href="/lib/pace/pace-theme-minimal.min.css">
  15. <script src="/lib/pace/pace.min.js"></script>
  16. <script id="hexo-configurations">
  17. var NexT = window.NexT || {};
  18. var CONFIG = {"hostname":"yoursite.com","root":"/","scheme":"Muse","version":"7.7.2","exturl":false,"sidebar":{"position":"left","display":"post","padding":18,"offset":12,"onmobile":false},"copycode":{"enable":true,"show_result":true,"style":null},"back2top":{"enable":true,"sidebar":false,"scrollpercent":true},"bookmark":{"enable":false,"color":"#222","save":"auto"},"fancybox":false,"mediumzoom":false,"lazyload":false,"pangu":false,"comments":{"style":"tabs","active":null,"storage":true,"lazyload":false,"nav":null},"algolia":{"hits":{"per_page":10},"labels":{"input_placeholder":"Search for Posts","hits_empty":"We didn't find any results for the search: ${query}","hits_stats":"${hits} results found in ${time} ms"}},"localsearch":{"enable":false,"trigger":"auto","top_n_per_article":1,"unescape":false,"preload":false},"motion":{"enable":true,"async":false,"transition":{"post_block":"fadeIn","post_header":"slideDownIn","post_body":"slideDownIn","coll_header":"slideLeftIn","sidebar":"slideLeftIn"}}};
  19. </script>
  20. <meta name="description" content="前置知识 数组,结构体,二叉树 引入 有时候我们会遇到一些大规模的区间查找和区间修改问题,比如让你维护一个 10510^5105 长度的数列,要求操作有区间求和、区间加(区间每个数加上一个值),让你在一秒内完成 10510^5105 次操作。 暴力是肯定不行的,数据范围太大,会超时。 所以我们就有一种专门解决大范围区间修改查询的数据结构:线段树。">
  21. <meta property="og:type" content="article">
  22. <meta property="og:title" content="线段树">
  23. <meta property="og:url" content="http://yoursite.com/2020/03/02/segment-tree/index.html">
  24. <meta property="og:site_name" content="Schtonn&#39;s Blog">
  25. <meta property="og:description" content="前置知识 数组,结构体,二叉树 引入 有时候我们会遇到一些大规模的区间查找和区间修改问题,比如让你维护一个 10510^5105 长度的数列,要求操作有区间求和、区间加(区间每个数加上一个值),让你在一秒内完成 10510^5105 次操作。 暴力是肯定不行的,数据范围太大,会超时。 所以我们就有一种专门解决大范围区间修改查询的数据结构:线段树。">
  26. <meta property="og:locale" content="en_US">
  27. <meta property="article:published_time" content="2020-03-02T03:37:36.000Z">
  28. <meta property="article:modified_time" content="2020-03-03T12:40:21.347Z">
  29. <meta property="article:author" content="Schtonn">
  30. <meta property="article:tag" content="graph">
  31. <meta name="twitter:card" content="summary">
  32. <link rel="canonical" href="http://yoursite.com/2020/03/02/segment-tree/">
  33. <script id="page-configurations">
  34. // https://hexo.io/docs/variables.html
  35. CONFIG.page = {
  36. sidebar: "",
  37. isHome : false,
  38. isPost : true
  39. };
  40. </script>
  41. <title>线段树 | Schtonn's Blog</title>
  42. <noscript>
  43. <style>
  44. .use-motion .brand,
  45. .use-motion .menu-item,
  46. .sidebar-inner,
  47. .use-motion .post-block,
  48. .use-motion .pagination,
  49. .use-motion .comments,
  50. .use-motion .post-header,
  51. .use-motion .post-body,
  52. .use-motion .collection-header { opacity: initial; }
  53. .use-motion .site-title,
  54. .use-motion .site-subtitle {
  55. opacity: initial;
  56. top: initial;
  57. }
  58. .use-motion .logo-line-before i { left: initial; }
  59. .use-motion .logo-line-after i { right: initial; }
  60. </style>
  61. </noscript>
  62. </head>
  63. <body itemscope itemtype="http://schema.org/WebPage">
  64. <div class="container use-motion">
  65. <div class="headband"></div>
  66. <header class="header" itemscope itemtype="http://schema.org/WPHeader">
  67. <div class="header-inner"><div class="site-brand-container">
  68. <div class="site-nav-toggle">
  69. <div class="toggle" aria-label="Toggle navigation bar">
  70. <span class="toggle-line toggle-line-first"></span>
  71. <span class="toggle-line toggle-line-middle"></span>
  72. <span class="toggle-line toggle-line-last"></span>
  73. </div>
  74. </div>
  75. <div class="site-meta">
  76. <div>
  77. <a href="/" class="brand" rel="start">
  78. <span class="logo-line-before"><i></i></span>
  79. <span class="site-title">Schtonn's Blog</span>
  80. <span class="logo-line-after"><i></i></span>
  81. </a>
  82. </div>
  83. <p class="site-subtitle">Schtonn's blog</p>
  84. </div>
  85. <div class="site-nav-right">
  86. <div class="toggle popup-trigger">
  87. </div>
  88. </div>
  89. </div>
  90. <nav class="site-nav">
  91. <ul id="menu" class="menu">
  92. <li class="menu-item menu-item-home">
  93. <a href="/" rel="section"><i class="fa fa-fw fa-home"></i>Home</a>
  94. </li>
  95. <li class="menu-item menu-item-tags">
  96. <a href="/tags/" rel="section"><i class="fa fa-fw fa-tags"></i>Tags</a>
  97. </li>
  98. <li class="menu-item menu-item-archives">
  99. <a href="/archives/" rel="section"><i class="fa fa-fw fa-archive"></i>Archives</a>
  100. </li>
  101. </ul>
  102. </nav>
  103. </div>
  104. </header>
  105. <div class="back-to-top">
  106. <i class="fa fa-arrow-up"></i>
  107. <span>0%</span>
  108. </div>
  109. <div class="reading-progress-bar"></div>
  110. <main class="main">
  111. <div class="main-inner">
  112. <div class="content-wrap">
  113. <div class="content">
  114. <div class="posts-expand">
  115. <article itemscope itemtype="http://schema.org/Article" class="post-block " lang="en">
  116. <link itemprop="mainEntityOfPage" href="http://yoursite.com/2020/03/02/segment-tree/">
  117. <span hidden itemprop="author" itemscope itemtype="http://schema.org/Person">
  118. <meta itemprop="image" content="/images/avatar.gif">
  119. <meta itemprop="name" content="Schtonn">
  120. <meta itemprop="description" content="">
  121. </span>
  122. <span hidden itemprop="publisher" itemscope itemtype="http://schema.org/Organization">
  123. <meta itemprop="name" content="Schtonn's Blog">
  124. </span>
  125. <header class="post-header">
  126. <h1 class="post-title" itemprop="name headline">
  127. 线段树
  128. </h1>
  129. <div class="post-meta">
  130. <span class="post-meta-item">
  131. <span class="post-meta-item-icon">
  132. <i class="fa fa-calendar-o"></i>
  133. </span>
  134. <span class="post-meta-item-text">Posted on</span>
  135. <time title="Created: 2020-Mar-02 11:37:36" itemprop="dateCreated datePublished" datetime="2020-03-02T11:37:36+08:00">2020-Mar-02</time>
  136. </span>
  137. <span class="post-meta-item">
  138. <span class="post-meta-item-icon">
  139. <i class="fa fa-calendar-check-o"></i>
  140. </span>
  141. <span class="post-meta-item-text">Edited on</span>
  142. <time title="Modified: 2020-Mar-03 20:40:21" itemprop="dateModified" datetime="2020-03-03T20:40:21+08:00">2020-Mar-03</time>
  143. </span>
  144. </div>
  145. </header>
  146. <div class="post-body" itemprop="articleBody">
  147. <h3 id="前置知识"><a class="markdownIt-Anchor" href="#前置知识"></a> 前置知识</h3>
  148. <p>数组,结构体,二叉树</p>
  149. <h3 id="引入"><a class="markdownIt-Anchor" href="#引入"></a> 引入</h3>
  150. <p>有时候我们会遇到一些大规模的区间查找和区间修改问题,比如让你维护一个 <span class="katex"><span class="katex-mathml"><math><semantics><mrow><mn>1</mn><msup><mn>0</mn><mn>5</mn></msup></mrow><annotation encoding="application/x-tex">10^5</annotation></semantics></math></span><span class="katex-html" aria-hidden="true"><span class="base"><span class="strut" style="height:0.8141079999999999em;vertical-align:0em;"></span><span class="mord">1</span><span class="mord"><span class="mord">0</span><span class="msupsub"><span class="vlist-t"><span class="vlist-r"><span class="vlist" style="height:0.8141079999999999em;"><span style="top:-3.063em;margin-right:0.05em;"><span class="pstrut" style="height:2.7em;"></span><span class="sizing reset-size6 size3 mtight"><span class="mord mtight">5</span></span></span></span></span></span></span></span></span></span></span> 长度的数列,要求操作有区间求和、区间加(区间每个数加上一个值),让你在一秒内完成 <span class="katex"><span class="katex-mathml"><math><semantics><mrow><mn>1</mn><msup><mn>0</mn><mn>5</mn></msup></mrow><annotation encoding="application/x-tex">10^5</annotation></semantics></math></span><span class="katex-html" aria-hidden="true"><span class="base"><span class="strut" style="height:0.8141079999999999em;vertical-align:0em;"></span><span class="mord">1</span><span class="mord"><span class="mord">0</span><span class="msupsub"><span class="vlist-t"><span class="vlist-r"><span class="vlist" style="height:0.8141079999999999em;"><span style="top:-3.063em;margin-right:0.05em;"><span class="pstrut" style="height:2.7em;"></span><span class="sizing reset-size6 size3 mtight"><span class="mord mtight">5</span></span></span></span></span></span></span></span></span></span></span> 次操作。<br />
  151. 暴力是肯定不行的,数据范围太大,会超时。<br />
  152. 所以我们就有一种专门解决大范围区间修改查询的数据结构:线段树。</p>
  153. <a id="more"></a>
  154. <h3 id="线段树"><a class="markdownIt-Anchor" href="#线段树"></a> 线段树</h3>
  155. <p>线段树本质上是把整个数列拆分了,用一个一个区间来表示。<br />
  156. 比如有 <span class="katex"><span class="katex-mathml"><math><semantics><mrow><mi>n</mi></mrow><annotation encoding="application/x-tex">n</annotation></semantics></math></span><span class="katex-html" aria-hidden="true"><span class="base"><span class="strut" style="height:0.43056em;vertical-align:0em;"></span><span class="mord mathdefault">n</span></span></span></span>个节点<br />
  157. 根节点代表整个数列的区间<span class="katex"><span class="katex-mathml"><math><semantics><mrow><mo stretchy="false">[</mo><mn>1</mn><mo separator="true">,</mo><mi>n</mi><mo stretchy="false">]</mo></mrow><annotation encoding="application/x-tex">[1,n]</annotation></semantics></math></span><span class="katex-html" aria-hidden="true"><span class="base"><span class="strut" style="height:1em;vertical-align:-0.25em;"></span><span class="mopen">[</span><span class="mord">1</span><span class="mpunct">,</span><span class="mspace" style="margin-right:0.16666666666666666em;"></span><span class="mord mathdefault">n</span><span class="mclose">]</span></span></span></span>,<br />
  158. 根节点的两个子节点代表根区间二分成两部分,也就是 <span class="katex"><span class="katex-mathml"><math><semantics><mrow><mo stretchy="false">[</mo><mn>1</mn><mo separator="true">,</mo><mi mathvariant="normal">mid</mi><mo>⁡</mo><mo stretchy="false">]</mo></mrow><annotation encoding="application/x-tex">[1,\operatorname{mid}]</annotation></semantics></math></span><span class="katex-html" aria-hidden="true"><span class="base"><span class="strut" style="height:1em;vertical-align:-0.25em;"></span><span class="mopen">[</span><span class="mord">1</span><span class="mpunct">,</span><span class="mspace" style="margin-right:0.16666666666666666em;"></span><span class="mop"><span class="mord mathrm">m</span><span class="mord mathrm">i</span><span class="mord mathrm">d</span></span><span class="mclose">]</span></span></span></span> 和 <span class="katex"><span class="katex-mathml"><math><semantics><mrow><mo stretchy="false">[</mo><mi mathvariant="normal">mid</mi><mo>⁡</mo><mo separator="true">,</mo><mi>n</mi><mo stretchy="false">]</mo></mrow><annotation encoding="application/x-tex">[\operatorname{mid},n]</annotation></semantics></math></span><span class="katex-html" aria-hidden="true"><span class="base"><span class="strut" style="height:1em;vertical-align:-0.25em;"></span><span class="mopen">[</span><span class="mop"><span class="mord mathrm">m</span><span class="mord mathrm">i</span><span class="mord mathrm">d</span></span><span class="mpunct">,</span><span class="mspace" style="margin-right:0.16666666666666666em;"></span><span class="mord mathdefault">n</span><span class="mclose">]</span></span></span></span>。<br />
  159. 而子节点也是一棵线段树。<br />
  160. 一直往下眼神,叶子结点就代表着单一位置<span class="katex"><span class="katex-mathml"><math><semantics><mrow><mo stretchy="false">[</mo><mi>a</mi><mo separator="true">,</mo><mi>a</mi><mo stretchy="false">]</mo></mrow><annotation encoding="application/x-tex">[a,a]</annotation></semantics></math></span><span class="katex-html" aria-hidden="true"><span class="base"><span class="strut" style="height:1em;vertical-align:-0.25em;"></span><span class="mopen">[</span><span class="mord mathdefault">a</span><span class="mpunct">,</span><span class="mspace" style="margin-right:0.16666666666666666em;"></span><span class="mord mathdefault">a</span><span class="mclose">]</span></span></span></span></p>
  161. </div>
  162. <div>
  163. <ul class="post-copyright">
  164. <li class="post-copyright-author">
  165. <strong>Post author: </strong>Schtonn
  166. </li>
  167. <li class="post-copyright-link">
  168. <strong>Post link: </strong>
  169. <a href="http://yoursite.com/2020/03/02/segment-tree/" title="线段树">http://yoursite.com/2020/03/02/segment-tree/</a>
  170. </li>
  171. <li class="post-copyright-license">
  172. <strong>Copyright Notice: </strong>All articles in this blog are licensed under <a href="https://creativecommons.org/licenses/by-nc-sa/4.0/" rel="noopener" target="_blank"><i class="fa fa-fw fa-creative-commons"></i>BY-NC-SA</a> unless stating additionally.
  173. </li>
  174. </ul>
  175. </div>
  176. <footer class="post-footer">
  177. <div class="post-tags">
  178. <a href="/tags/graph/" rel="tag"># graph</a>
  179. </div>
  180. <div class="post-nav">
  181. <div class="post-nav-item">
  182. <a href="/2020/03/02/ferbonacci/" rel="prev" title="斐波那契数列-O(1)">
  183. <i class="fa fa-chevron-left"></i> 斐波那契数列-O(1)
  184. </a></div>
  185. <div class="post-nav-item"></div>
  186. </div>
  187. </footer>
  188. </article>
  189. </div>
  190. </div>
  191. <script>
  192. window.addEventListener('tabs:register', () => {
  193. let activeClass = CONFIG.comments.activeClass;
  194. if (CONFIG.comments.storage) {
  195. activeClass = localStorage.getItem('comments_active') || activeClass;
  196. }
  197. if (activeClass) {
  198. let activeTab = document.querySelector(`a[href="#comment-${activeClass}"]`);
  199. if (activeTab) {
  200. activeTab.click();
  201. }
  202. }
  203. });
  204. if (CONFIG.comments.storage) {
  205. window.addEventListener('tabs:click', event => {
  206. if (!event.target.matches('.tabs-comment .tab-content .tab-pane')) return;
  207. let commentClass = event.target.classList[1];
  208. localStorage.setItem('comments_active', commentClass);
  209. });
  210. }
  211. </script>
  212. </div>
  213. <div class="toggle sidebar-toggle">
  214. <span class="toggle-line toggle-line-first"></span>
  215. <span class="toggle-line toggle-line-middle"></span>
  216. <span class="toggle-line toggle-line-last"></span>
  217. </div>
  218. <aside class="sidebar">
  219. <div class="sidebar-inner">
  220. <ul class="sidebar-nav motion-element">
  221. <li class="sidebar-nav-toc">
  222. Table of Contents
  223. </li>
  224. <li class="sidebar-nav-overview">
  225. Overview
  226. </li>
  227. </ul>
  228. <!--noindex-->
  229. <div class="post-toc-wrap sidebar-panel">
  230. <div class="post-toc motion-element"><ol class="nav"><li class="nav-item nav-level-3"><a class="nav-link" href="#前置知识"><span class="nav-number">1.</span> <span class="nav-text"> 前置知识</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#引入"><span class="nav-number">2.</span> <span class="nav-text"> 引入</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#线段树"><span class="nav-number">3.</span> <span class="nav-text"> 线段树</span></a></li></ol></div>
  231. </div>
  232. <!--/noindex-->
  233. <div class="site-overview-wrap sidebar-panel">
  234. <div class="site-author motion-element" itemprop="author" itemscope itemtype="http://schema.org/Person">
  235. <p class="site-author-name" itemprop="name">Schtonn</p>
  236. <div class="site-description" itemprop="description"></div>
  237. </div>
  238. <div class="site-state-wrap motion-element">
  239. <nav class="site-state">
  240. <div class="site-state-item site-state-posts">
  241. <a href="/archives/">
  242. <span class="site-state-item-count">8</span>
  243. <span class="site-state-item-name">posts</span>
  244. </a>
  245. </div>
  246. <div class="site-state-item site-state-tags">
  247. <a href="/tags/">
  248. <span class="site-state-item-count">4</span>
  249. <span class="site-state-item-name">tags</span></a>
  250. </div>
  251. </nav>
  252. </div>
  253. <div class="links-of-blogroll motion-element">
  254. <div class="links-of-blogroll-title">
  255. <i class="fa fa-fw fa-link"></i>
  256. Links
  257. </div>
  258. <ul class="links-of-blogroll-list">
  259. <li class="links-of-blogroll-item">
  260. <a href="https://yonghong.github.io/" title="https:&#x2F;&#x2F;yonghong.github.io" rel="noopener" target="_blank">Yonghong</a>
  261. </li>
  262. </ul>
  263. </div>
  264. </div>
  265. <div id="treefrog" style="text-align: center;margin-top: 18px;">
  266. <object type="application/x-shockwave-flash" style="outline:none;" data="/js/treefrog.swf?up_bodyColor=444444&up_pattern=0&up_flyColor=777777&up_tongueColor=555555&up_patternColor=000000&up_releaseFly=0&up_frogName=Froggie&up_backgroundImage=http://&up_bellySize=.5&up_footColor=444444&up_eyeColor=444444&up_backgroundColor=222222&" width="300" height="600"><param name="movie" value="http://cdn.abowman.com/widgets/treefrog/treefrog.swf?up_bodyColor=444444&up_pattern=0&up_flyColor=777777&up_tongueColor=555555&up_patternColor=000000&up_releaseFly=0&up_frogName=Froggie&up_backgroundImage=http://&up_bellySize=.5&up_footColor=444444&up_eyeColor=444444&up_backgroundColor=222222&"></param><param name="AllowScriptAccess" value="always"></param><param name="wmode" value="opaque"></param><param name="scale" value="noscale"/><param name="salign" value="tl"/></object>
  267. </div>
  268. </div>
  269. </aside>
  270. <div id="sidebar-dimmer"></div>
  271. </div>
  272. </main>
  273. <footer class="footer">
  274. <div class="footer-inner">
  275. <div class="copyright">
  276. &copy;
  277. <span itemprop="copyrightYear">2020</span>
  278. <span class="with-love">
  279. <i class="fa fa-user"></i>
  280. </span>
  281. <span class="author" itemprop="copyrightHolder">Alex Xiang</span>
  282. </div>
  283. <div class="powered-by">Powered by <a href="https://hexo.io/" class="theme-link" rel="noopener" target="_blank">Hexo</a>
  284. </div>
  285. <span class="post-meta-divider">|</span>
  286. <div class="theme-info">Theme – <a href="https://muse.theme-next.org/" class="theme-link" rel="noopener" target="_blank">NexT.Muse</a>
  287. </div>
  288. </div>
  289. </footer>
  290. </div>
  291. <script src="/lib/anime.min.js"></script>
  292. <script src="/lib/velocity/velocity.min.js"></script>
  293. <script src="/lib/velocity/velocity.ui.min.js"></script>
  294. <script src="/js/utils.js"></script>
  295. <script src="/js/motion.js"></script>
  296. <script src="/js/schemes/muse.js"></script>
  297. <script src="/js/next-boot.js"></script>
  298. <link rel="stylesheet" href="//cdn.jsdelivr.net/npm/katex@0/dist/katex.min.css">
  299. </body>
  300. </html>