index.html 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>线段树 | Schtonn&#39;s Blog</title>
  6. <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  7. <meta name="description" content="前置知识 数组,结构体,二叉树 引入 有时候我们会遇到一些大规模的区间查找和区间修改问题,比如让你维护一个 \(10^5\) 长度的数列,要求操作有区间求和、区间加(区间每个数加上一个值),让你在一秒内完成 \(10^5\) 次操作。 暴力是肯定不行的,数据范围太大,会超时。 所以我们就有一种专门解决大范围区间修改查询的数据结构:线段树。">
  8. <meta property="og:type" content="article">
  9. <meta property="og:title" content="线段树">
  10. <meta property="og:url" content="http://yoursite.com/2020/03/02/segment-tree/index.html">
  11. <meta property="og:site_name" content="Schtonn&#39;s Blog">
  12. <meta property="og:description" content="前置知识 数组,结构体,二叉树 引入 有时候我们会遇到一些大规模的区间查找和区间修改问题,比如让你维护一个 \(10^5\) 长度的数列,要求操作有区间求和、区间加(区间每个数加上一个值),让你在一秒内完成 \(10^5\) 次操作。 暴力是肯定不行的,数据范围太大,会超时。 所以我们就有一种专门解决大范围区间修改查询的数据结构:线段树。">
  13. <meta property="og:locale" content="en_US">
  14. <meta property="article:published_time" content="2020-03-02T03:37:36.000Z">
  15. <meta property="article:modified_time" content="2020-03-03T12:40:21.347Z">
  16. <meta property="article:author" content="Schtonn">
  17. <meta property="article:tag" content="graph">
  18. <meta name="twitter:card" content="summary">
  19. <link rel="alternate" href="/atom.xml" title="Schtonn&#39;s Blog" type="application/atom+xml">
  20. <link rel="icon" href="/favicon.png">
  21. <link href="//fonts.googleapis.com/css?family=Source+Code+Pro" rel="stylesheet" type="text/css">
  22. <link rel="stylesheet" href="/css/style.css">
  23. <meta name="generator" content="Hexo 4.2.0"></head>
  24. <body>
  25. <div id="container">
  26. <div id="wrap">
  27. <header id="header">
  28. <div id="banner"></div>
  29. <div id="header-outer" class="outer">
  30. <div id="header-title" class="inner">
  31. <h1 id="logo-wrap">
  32. <a href="/" id="logo">Schtonn&#39;s Blog</a>
  33. </h1>
  34. <h2 id="subtitle-wrap">
  35. <a href="/" id="subtitle">Schtonn&#39;s blog</a>
  36. </h2>
  37. </div>
  38. <div id="header-inner" class="inner">
  39. <nav id="main-nav">
  40. <a id="main-nav-toggle" class="nav-icon"></a>
  41. <a class="main-nav-link" href="/">Home</a>
  42. <a class="main-nav-link" href="/archives">Archives</a>
  43. </nav>
  44. <nav id="sub-nav">
  45. <a id="nav-rss-link" class="nav-icon" href="/atom.xml" title="RSS Feed"></a>
  46. <a id="nav-search-btn" class="nav-icon" title="Search"></a>
  47. </nav>
  48. <div id="search-form-wrap">
  49. <form action="//google.com/search" method="get" accept-charset="UTF-8" class="search-form"><input type="search" name="q" class="search-form-input" placeholder="Search"><button type="submit" class="search-form-submit">&#xF002;</button><input type="hidden" name="sitesearch" value="http://yoursite.com"></form>
  50. </div>
  51. </div>
  52. </div>
  53. </header>
  54. <div class="outer">
  55. <section id="main"><article id="post-segment-tree" class="article article-type-post" itemscope itemprop="blogPost">
  56. <div class="article-meta">
  57. <a href="/2020/03/02/segment-tree/" class="article-date">
  58. <time datetime="2020-03-02T03:37:36.000Z" itemprop="datePublished">2020-Mar-02</time>
  59. </a>
  60. </div>
  61. <div class="article-inner">
  62. <header class="article-header">
  63. <h1 class="article-title" itemprop="name">
  64. 线段树
  65. </h1>
  66. </header>
  67. <div class="article-entry" itemprop="articleBody">
  68. <h3 id="前置知识">前置知识</h3>
  69. <p>数组,结构体,二叉树</p>
  70. <h3 id="引入">引入</h3>
  71. <p>有时候我们会遇到一些大规模的区间查找和区间修改问题,比如让你维护一个 <span class="math inline">\(10^5\)</span> 长度的数列,要求操作有区间求和、区间加(区间每个数加上一个值),让你在一秒内完成 <span class="math inline">\(10^5\)</span> 次操作。 暴力是肯定不行的,数据范围太大,会超时。 所以我们就有一种专门解决大范围区间修改查询的数据结构:线段树。</p>
  72. <a id="more"></a>
  73. <h3 id="线段树">线段树</h3>
  74. <p>线段树本质上是把整个数列拆分了,用一个一个区间来表示。 比如有 <span class="math inline">\(n\)</span>个节点 根节点代表整个数列的区间<span class="math inline">\([1,n]\)</span>, 根节点的两个子节点代表根区间二分成两部分,也就是 <span class="math inline">\([1,\operatorname{mid}]\)</span> 和 <span class="math inline">\([\operatorname{mid},n]\)</span>。 而子节点也是一棵线段树。 一直往下眼神,叶子结点就代表着单一位置<span class="math inline">\([a,a]\)</span></p>
  75. </div>
  76. <footer class="article-footer">
  77. <a data-url="http://yoursite.com/2020/03/02/segment-tree/" data-id="ck7cjuv730004pc13034b6qa3" class="article-share-link">Share</a>
  78. <ul class="article-tag-list" itemprop="keywords"><li class="article-tag-list-item"><a class="article-tag-list-link" href="/tags/graph/" rel="tag">graph</a></li></ul>
  79. </footer>
  80. </div>
  81. <nav id="article-nav">
  82. <a href="/2020/03/02/ferbonacci/" id="article-nav-older" class="article-nav-link-wrap">
  83. <strong class="article-nav-caption">Older</strong>
  84. <div class="article-nav-title">斐波那契数列-O(1)</div>
  85. </a>
  86. </nav>
  87. </article>
  88. </section>
  89. <aside id="sidebar">
  90. <div class="widget-wrap">
  91. <h3 class="widget-title">Tags</h3>
  92. <div class="widget">
  93. <ul class="tag-list" itemprop="keywords"><li class="tag-list-item"><a class="tag-list-link" href="/tags/graph/" rel="tag">graph</a></li><li class="tag-list-item"><a class="tag-list-link" href="/tags/math/" rel="tag">math</a></li><li class="tag-list-item"><a class="tag-list-link" href="/tags/other/" rel="tag">other</a></li><li class="tag-list-item"><a class="tag-list-link" href="/tags/struct/" rel="tag">struct</a></li></ul>
  94. </div>
  95. </div>
  96. <div class="widget-wrap">
  97. <h3 class="widget-title">Tag Cloud</h3>
  98. <div class="widget tagcloud">
  99. <a href="/tags/graph/" style="font-size: 20px;">graph</a> <a href="/tags/math/" style="font-size: 10px;">math</a> <a href="/tags/other/" style="font-size: 15px;">other</a> <a href="/tags/struct/" style="font-size: 10px;">struct</a>
  100. </div>
  101. </div>
  102. <div class="widget-wrap">
  103. <h3 class="widget-title">Archives</h3>
  104. <div class="widget">
  105. <ul class="archive-list"><li class="archive-list-item"><a class="archive-list-link" href="/archives/2020/03/">March 2020</a></li></ul>
  106. </div>
  107. </div>
  108. <div class="widget-wrap">
  109. <h3 class="widget-title">Recent Posts</h3>
  110. <div class="widget">
  111. <ul>
  112. <li>
  113. <a href="/2020/03/02/segment-tree/">线段树</a>
  114. </li>
  115. <li>
  116. <a href="/2020/03/02/ferbonacci/">斐波那契数列-O(1)</a>
  117. </li>
  118. <li>
  119. <a href="/2020/03/02/dinic/">网络最大流-Dinic</a>
  120. </li>
  121. <li>
  122. <a href="/2020/03/01/min-span-tree/">最小生成树</a>
  123. </li>
  124. <li>
  125. <a href="/2020/03/01/union-find/">并查集</a>
  126. </li>
  127. </ul>
  128. </div>
  129. </div>
  130. </aside>
  131. </div>
  132. <footer id="footer">
  133. <div class="outer">
  134. <div id="footer-info" class="inner">
  135. &copy; 2020 Schtonn<br>
  136. Powered by <a href="http://hexo.io/" target="_blank">Hexo</a>
  137. </div>
  138. </div>
  139. </footer>
  140. </div>
  141. <nav id="mobile-nav">
  142. <a href="/" class="mobile-nav-link">Home</a>
  143. <a href="/archives" class="mobile-nav-link">Archives</a>
  144. </nav>
  145. <script src="//ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>
  146. <link rel="stylesheet" href="/fancybox/jquery.fancybox.css">
  147. <script src="/fancybox/jquery.fancybox.pack.js"></script>
  148. <script src="/js/script.js"></script>
  149. </div>
  150. </body>
  151. </html>