index.html 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591
  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="/blog/images/apple-touch-icon-next.png">
  9. <link rel="icon" type="image/png" sizes="32x32" href="/blog/images/favicon-frog.png">
  10. <link rel="icon" type="image/png" sizes="16x16" href="/blog/images/favicon-frog.png">
  11. <link rel="mask-icon" href="/blog/images/logo.svg" color="#222">
  12. <link rel="stylesheet" href="/blog/css/main.css">
  13. <link rel="stylesheet" href="//fonts.googleapis.com/css?family=Comic Sans MS:300,300italic,400,400italic,700,700italic|Consolas:300,300italic,400,400italic,700,700italic&display=swap&subset=latin,latin-ext">
  14. <link rel="stylesheet" href="/blog/lib/font-awesome/css/font-awesome.min.css">
  15. <link rel="stylesheet" href="//cdn.jsdelivr.net/gh/fancyapps/fancybox@3/dist/jquery.fancybox.min.css">
  16. <link rel="stylesheet" href="/blog/lib/pace/pace-theme-minimal.min.css">
  17. <script src="/blog/lib/pace/pace.min.js"></script>
  18. <script id="hexo-configurations">
  19. var NexT = window.NexT || {};
  20. var CONFIG = {"hostname":"schtonn.github.io","root":"/blog/","scheme":"Muse","version":"7.8.0","exturl":false,"sidebar":{"position":"left","display":"post","padding":18,"offset":12,"onmobile":false},"copycode":{"enable":true,"show_result":true,"style":"flat"},"back2top":{"enable":true,"sidebar":false,"scrollpercent":true},"bookmark":{"enable":false,"color":"#222","save":"auto"},"fancybox":true,"mediumzoom":false,"lazyload":true,"pangu":false,"comments":{"style":"tabs","active":"valine","storage":true,"lazyload":false,"nav":null,"activeClass":"valine"},"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":"slideUpIn"}}};
  21. </script>
  22. <meta name="description" content="前置知识 存图方式(邻接表,邻接矩阵),图的遍历(dfs,bfs) 引入 我们举个例子吧: 有一个毒瘤水管工,他会造水管,有一天他造了一个水管网络,就像一个图。其中有一个点只有出边,就是起点,还有一个点只有入边,是终点。 点之间有一些管子,这些管子都有单位时间内的容量,现在毒瘤水管工想知道,他的管子在单位时间内在起点终点之间最多能流多少水。">
  23. <meta property="og:type" content="article">
  24. <meta property="og:title" content="网络最大流-Dinic">
  25. <meta property="og:url" content="https://schtonn.github.io/blog/posts/dinic/index.html">
  26. <meta property="og:site_name" content="Alex&#39;s Blog">
  27. <meta property="og:description" content="前置知识 存图方式(邻接表,邻接矩阵),图的遍历(dfs,bfs) 引入 我们举个例子吧: 有一个毒瘤水管工,他会造水管,有一天他造了一个水管网络,就像一个图。其中有一个点只有出边,就是起点,还有一个点只有入边,是终点。 点之间有一些管子,这些管子都有单位时间内的容量,现在毒瘤水管工想知道,他的管子在单位时间内在起点终点之间最多能流多少水。">
  28. <meta property="og:locale" content="en_US">
  29. <meta property="og:image" content="https://img-blog.csdnimg.cn/20200111112801923.png">
  30. <meta property="og:image" content="https://img-blog.csdnimg.cn/20200111114148208.png">
  31. <meta property="og:image" content="https://img-blog.csdnimg.cn/20200111112801923.png">
  32. <meta property="article:published_time" content="2020-03-02T03:31:22.000Z">
  33. <meta property="article:modified_time" content="2020-04-25T04:38:06.785Z">
  34. <meta property="article:author" content="Alex">
  35. <meta property="article:tag" content="graph">
  36. <meta name="twitter:card" content="summary">
  37. <meta name="twitter:image" content="https://img-blog.csdnimg.cn/20200111112801923.png">
  38. <link rel="canonical" href="https://schtonn.github.io/blog/posts/dinic/">
  39. <script id="page-configurations">
  40. // https://hexo.io/docs/variables.html
  41. CONFIG.page = {
  42. sidebar: "",
  43. isHome : false,
  44. isPost : true,
  45. lang : 'en'
  46. };
  47. </script>
  48. <title>网络最大流-Dinic | Alex's Blog</title>
  49. <noscript>
  50. <style>
  51. .use-motion .brand,
  52. .use-motion .menu-item,
  53. .sidebar-inner,
  54. .use-motion .post-block,
  55. .use-motion .pagination,
  56. .use-motion .comments,
  57. .use-motion .post-header,
  58. .use-motion .post-body,
  59. .use-motion .collection-header { opacity: initial; }
  60. .use-motion .site-title,
  61. .use-motion .site-subtitle {
  62. opacity: initial;
  63. top: initial;
  64. }
  65. .use-motion .logo-line-before i { left: initial; }
  66. .use-motion .logo-line-after i { right: initial; }
  67. </style>
  68. </noscript>
  69. </head>
  70. <body itemscope itemtype="http://schema.org/WebPage">
  71. <div class="container use-motion">
  72. <div class="headband"></div>
  73. <header class="header" itemscope itemtype="http://schema.org/WPHeader">
  74. <div class="header-inner"><div class="site-brand-container">
  75. <div class="site-nav-toggle">
  76. <div class="toggle" aria-label="Toggle navigation bar">
  77. <span class="toggle-line toggle-line-first"></span>
  78. <span class="toggle-line toggle-line-middle"></span>
  79. <span class="toggle-line toggle-line-last"></span>
  80. </div>
  81. </div>
  82. <div class="site-meta">
  83. <a href="/blog/" class="brand" rel="start">
  84. <span class="logo-line-before"><i></i></span>
  85. <h1 class="site-title">Alex's Blog</h1>
  86. <span class="logo-line-after"><i></i></span>
  87. </a>
  88. <p class="site-subtitle" itemprop="description">schtonn</p>
  89. </div>
  90. <div class="site-nav-right">
  91. <div class="toggle popup-trigger">
  92. </div>
  93. </div>
  94. </div>
  95. <nav class="site-nav">
  96. <ul id="menu" class="menu">
  97. <li class="menu-item menu-item-home">
  98. <a href="/blog/" rel="section"><i class="fa fa-fw fa-home"></i>Home</a>
  99. </li>
  100. <li class="menu-item menu-item-tags">
  101. <a href="/blog/tags/" rel="section"><i class="fa fa-fw fa-tags"></i>Tags</a>
  102. </li>
  103. <li class="menu-item menu-item-archives">
  104. <a href="/blog/archives/" rel="section"><i class="fa fa-fw fa-archive"></i>Archives</a>
  105. </li>
  106. <li class="menu-item menu-item-games">
  107. <a href="/blog/games/" rel="section"><i class="fa fa-fw fa-gamepad"></i>Games</a>
  108. </li>
  109. </ul>
  110. </nav>
  111. </div>
  112. </header>
  113. <div class="back-to-top">
  114. <i class="fa fa-arrow-up"></i>
  115. <span>0%</span>
  116. </div>
  117. <div class="reading-progress-bar"></div>
  118. <main class="main">
  119. <div class="main-inner">
  120. <div class="content-wrap">
  121. <div class="content post posts-expand">
  122. <article itemscope itemtype="http://schema.org/Article" class="post-block" lang="en">
  123. <link itemprop="mainEntityOfPage" href="https://schtonn.github.io/blog/posts/dinic/">
  124. <span hidden itemprop="author" itemscope itemtype="http://schema.org/Person">
  125. <meta itemprop="image" content="/blog/images/avatar.gif">
  126. <meta itemprop="name" content="Alex">
  127. <meta itemprop="description" content="">
  128. </span>
  129. <script>
  130. (function(){
  131. if(''){
  132. if (prompt('This page is locked.\nPlease enter the password.') !== ''){
  133. alert('hamar');
  134. history.back();
  135. }
  136. }
  137. })();
  138. </script>
  139. <script>
  140. document.oncopy = function (event){
  141. alert("no");
  142. if(window.event){
  143. event = window.event;
  144. }try{
  145. var the = event.srcElement;
  146. if(!((the.tagName == "INPUT" && the.type.toLowerCase() == "text") || the.tagName == "TEXTAREA")){
  147. return false;
  148. }
  149. return true;
  150. }catch (e){
  151. return false;
  152. }
  153. }
  154. </script>
  155. <span hidden itemprop="publisher" itemscope itemtype="http://schema.org/Organization">
  156. <meta itemprop="name" content="Alex's Blog">
  157. </span>
  158. <header class="post-header">
  159. <h1 class="post-title" itemprop="name headline">
  160. 网络最大流-Dinic
  161. </h1>
  162. <div class="post-meta">
  163. <span class="post-meta-item">
  164. <span class="post-meta-item-icon">
  165. <i class="fa fa-calendar-o"></i>
  166. </span>
  167. <span class="post-meta-item-text">Posted on</span>
  168. <time title="Created: 2020-Mar-02 11:31:22" itemprop="dateCreated datePublished" datetime="2020-03-02T11:31:22+08:00">2020-Mar-02</time>
  169. </span>
  170. <span class="post-meta-item">
  171. <span class="post-meta-item-icon">
  172. <i class="fa fa-calendar-check-o"></i>
  173. </span>
  174. <span class="post-meta-item-text">Edited on</span>
  175. <time title="Modified: 2020-Apr-25 12:38:06" itemprop="dateModified" datetime="2020-04-25T12:38:06+08:00">2020-Apr-25</time>
  176. </span>
  177. <span class="post-meta-item">
  178. <span class="post-meta-item-icon">
  179. <i class="fa fa-comment-o"></i>
  180. </span>
  181. <span class="post-meta-item-text">Valine: </span>
  182. <a title="valine" href="/blog/posts/dinic/#valine-comments" itemprop="discussionUrl">
  183. <span class="post-comments-count valine-comment-count" data-xid="/blog/posts/dinic/" itemprop="commentCount"></span>
  184. </a>
  185. </span>
  186. </div>
  187. </header>
  188. <div class="post-body" itemprop="articleBody">
  189. <h3 id="前置知识"><a class="markdownIt-Anchor" href="#前置知识"></a> 前置知识</h3>
  190. <p>存图方式(<a href="http://baidu.physton.com/?q=%E9%82%BB%E6%8E%A5%E8%A1%A8" target="_blank" rel="noopener" title="简单">邻接表</a>,<a href="http://baidu.physton.com/?q=%E9%82%BB%E6%8E%A5%E7%9F%A9%E9%98%B5" target="_blank" rel="noopener" title="都太简单了">邻接矩阵</a>),图的遍历(<a href="http://baidu.physton.com/?q=dfs" target="_blank" rel="noopener" title="简单">dfs</a>,<a href="http://baidu.physton.com/?q=bfs" target="_blank" rel="noopener" title="简单">bfs</a>)</p>
  191. <h3 id="引入"><a class="markdownIt-Anchor" href="#引入"></a> 引入</h3>
  192. <p>我们举个例子吧:<br />
  193. 有一个毒瘤水管工,他会造水管,有一天他造了一个水管网络,就像一个图。其中有一个点只有出边,就是起点,还有一个点只有入边,是终点。<br />
  194. 点之间有一些管子,这些管子都有单位时间内的容量,现在毒瘤水管工想知道,他的管子在<strong>单位时间内</strong>在起点终点之间最多能流多少水。</p>
  195. <a id="more"></a>
  196. <h3 id="概念"><a class="markdownIt-Anchor" href="#概念"></a> 概念</h3>
  197. <ul>
  198. <li>源点:顾名思义,起点,一般用s表示</li>
  199. <li>汇点:顾名思义,终点,一般用t表示。。。</li>
  200. <li>容量:顾名思义。。。一条边单位时间内的的容量</li>
  201. <li>残余网络:进行增广后剩余的网络</li>
  202. <li>増广:</li>
  203. </ul>
  204. <blockquote>
  205. <p>増广就是在残余网络中寻找从源点到汇点的可行路径(増广路),并将该路径上的所有边的容量减去路径中的最小容量,形成新的残余网络,<strong>人话就是找一条能走的路,然后把路走掉。</strong><br />
  206. 例如:<br />
  207. <img data-src="https://img-blog.csdnimg.cn/20200111112801923.png" alt="在这里插入图片描述" /><br />
  208. 如果当前有这样一个残余网络,那么<span class="katex"><span class="katex-mathml"><math><semantics><mrow><mi>s</mi><mo>→</mo><mn>4</mn><mo>→</mo><mn>1</mn><mo>→</mo><mi>t</mi></mrow><annotation encoding="application/x-tex">s\rightarrow4\rightarrow1\rightarrow t</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">s</span><span class="mspace" style="margin-right:0.2777777777777778em;"></span><span class="mrel">→</span><span class="mspace" style="margin-right:0.2777777777777778em;"></span></span><span class="base"><span class="strut" style="height:0.64444em;vertical-align:0em;"></span><span class="mord">4</span><span class="mspace" style="margin-right:0.2777777777777778em;"></span><span class="mrel">→</span><span class="mspace" style="margin-right:0.2777777777777778em;"></span></span><span class="base"><span class="strut" style="height:0.64444em;vertical-align:0em;"></span><span class="mord">1</span><span class="mspace" style="margin-right:0.2777777777777778em;"></span><span class="mrel">→</span><span class="mspace" style="margin-right:0.2777777777777778em;"></span></span><span class="base"><span class="strut" style="height:0.61508em;vertical-align:0em;"></span><span class="mord mathdefault">t</span></span></span></span>就是一条増广路,最小容量是4,进行増广过后就形成了这样一张图:<br />
  209. <img data-src="https://img-blog.csdnimg.cn/20200111114148208.png" alt="在这里插入图片描述" /><br />
  210. 如何寻找増广路?直接dfs即可。</p>
  211. </blockquote>
  212. <ul>
  213. <li>反向边:</li>
  214. </ul>
  215. <blockquote>
  216. <p>有时候,程序増广的时候会出现爆炸性错误,例如还是那个图:<br />
  217. <img data-src="https://img-blog.csdnimg.cn/20200111112801923.png" alt="在这里插入图片描述" /><br />
  218. 有两条増广路,万一程序选错了怎么办?<br />
  219. 这时就要请出反向边了。<br />
  220. 每次増广的时候,<strong>在残余网络上逆着増广路径建容量与増广路径最小容量相等的反向边</strong>,比如刚才那张图,就顺着<span class="katex"><span class="katex-mathml"><math><semantics><mrow><mi>t</mi><mo>→</mo><mn>1</mn><mo>→</mo><mn>4</mn><mo>→</mo><mi>s</mi></mrow><annotation encoding="application/x-tex">t\rightarrow1\rightarrow4\rightarrow s</annotation></semantics></math></span><span class="katex-html" aria-hidden="true"><span class="base"><span class="strut" style="height:0.61508em;vertical-align:0em;"></span><span class="mord mathdefault">t</span><span class="mspace" style="margin-right:0.2777777777777778em;"></span><span class="mrel">→</span><span class="mspace" style="margin-right:0.2777777777777778em;"></span></span><span class="base"><span class="strut" style="height:0.64444em;vertical-align:0em;"></span><span class="mord">1</span><span class="mspace" style="margin-right:0.2777777777777778em;"></span><span class="mrel">→</span><span class="mspace" style="margin-right:0.2777777777777778em;"></span></span><span class="base"><span class="strut" style="height:0.64444em;vertical-align:0em;"></span><span class="mord">4</span><span class="mspace" style="margin-right:0.2777777777777778em;"></span><span class="mrel">→</span><span class="mspace" style="margin-right:0.2777777777777778em;"></span></span><span class="base"><span class="strut" style="height:0.43056em;vertical-align:0em;"></span><span class="mord mathdefault">s</span></span></span></span>建容量为4的边。相当于把原来的那条路抵消掉了,如果増广时走过了反向边,就相当于把原来的増广撤回去了。<br />
  221. 这就给了程序一个反悔的机会。</p>
  222. </blockquote>
  223. <h3 id="朴素算法"><a class="markdownIt-Anchor" href="#朴素算法"></a> 朴素算法</h3>
  224. <ol>
  225. <li>増广</li>
  226. <li>沿着増广路径建反向边</li>
  227. <li>如果源点与汇点依然连通,回到1</li>
  228. </ol>
  229. <h3 id="dinic优化"><a class="markdownIt-Anchor" href="#dinic优化"></a> Dinic优化</h3>
  230. <p>Dinic的优化就是用bfs建立了由s开始的一个分层图,每次寻找増广路时必须让边上的层数严格递增,就可以确保每一步都离汇点近了一些这样就不会陷入毒瘤数据卡成的死循环,比如这样的著名毒瘤数据:<br />
  231. ![](file://C:/Users/liangliang/Documents/Gridea/post-images/1582894458914.png)在这个数据中,如果用朴素算法,就会让中间容量为1的边上下抖动抽搐,等到他抽了999次的时候才把上面和下面的999减没。如果用Dinic,两次直接求出999+999。</p>
  232. <h3 id="代码"><a class="markdownIt-Anchor" href="#代码"></a> 代码</h3>
  233. <p><a href="https://schtonn.github.io/404.html"><code>404 Not Found(Click for more information)</code></a><br />
  234. 完结!</p>
  235. </div>
  236. <div class="reward-container">
  237. <div>Buy me a cup of coffee, T H A N K S.</div>
  238. <button onclick="var qr = document.getElementById('qr'); qr.style.display = (qr.style.display === 'none') ? 'block' : 'none';">
  239. Donate
  240. </button>
  241. <div id="qr" style="display: none;">
  242. <div style="display: inline-block;">
  243. <img src="/blog/images/wechat_channel.jpg" alt="Alex WeChat Pay">
  244. <p>WeChat Pay</p>
  245. </div>
  246. </div>
  247. </div>
  248. <div>
  249. <ul class="post-copyright">
  250. <li class="post-copyright-author">
  251. <strong>Post author: </strong>Alex
  252. </li>
  253. <li class="post-copyright-link">
  254. <strong>Post link: </strong>
  255. <a href="https://schtonn.github.io/blog/posts/dinic/" title="网络最大流-Dinic">https://schtonn.github.io/blog/posts/dinic/</a>
  256. </li>
  257. <li class="post-copyright-license">
  258. <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.
  259. </li>
  260. </ul>
  261. </div>
  262. <footer class="post-footer">
  263. <div class="post-tags">
  264. <a href="/blog/tags/graph/" rel="tag"><i class="fa fa-tag"></i> graph</a>
  265. </div>
  266. <div class="post-nav">
  267. <div class="post-nav-item">
  268. <a href="/blog/posts/min-span-tree/" rel="prev" title="最小生成树">
  269. <i class="fa fa-chevron-left"></i> 最小生成树
  270. </a></div>
  271. <div class="post-nav-item">
  272. <a href="/blog/posts/fibonacci/" rel="next" title="斐波那契数列-O(1)">
  273. 斐波那契数列-O(1) <i class="fa fa-chevron-right"></i>
  274. </a></div>
  275. </div>
  276. </footer>
  277. </article>
  278. </div>
  279. <div class="comments" id="valine-comments"></div>
  280. <script>
  281. window.addEventListener('tabs:register', () => {
  282. let { activeClass } = CONFIG.comments;
  283. if (CONFIG.comments.storage) {
  284. activeClass = localStorage.getItem('comments_active') || activeClass;
  285. }
  286. if (activeClass) {
  287. let activeTab = document.querySelector(`a[href="#comment-${activeClass}"]`);
  288. if (activeTab) {
  289. activeTab.click();
  290. }
  291. }
  292. });
  293. if (CONFIG.comments.storage) {
  294. window.addEventListener('tabs:click', event => {
  295. if (!event.target.matches('.tabs-comment .tab-content .tab-pane')) return;
  296. let commentClass = event.target.classList[1];
  297. localStorage.setItem('comments_active', commentClass);
  298. });
  299. }
  300. </script>
  301. </div>
  302. <div class="toggle sidebar-toggle">
  303. <span class="toggle-line toggle-line-first"></span>
  304. <span class="toggle-line toggle-line-middle"></span>
  305. <span class="toggle-line toggle-line-last"></span>
  306. </div>
  307. <aside class="sidebar">
  308. <div class="sidebar-inner">
  309. <ul class="sidebar-nav motion-element">
  310. <li class="sidebar-nav-toc">
  311. Table of Contents
  312. </li>
  313. <li class="sidebar-nav-overview">
  314. Overview
  315. </li>
  316. </ul>
  317. <!--noindex-->
  318. <div class="post-toc-wrap sidebar-panel">
  319. <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><li class="nav-item nav-level-3"><a class="nav-link" href="#朴素算法"><span class="nav-number">4.</span> <span class="nav-text"> 朴素算法</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#dinic优化"><span class="nav-number">5.</span> <span class="nav-text"> Dinic优化</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#代码"><span class="nav-number">6.</span> <span class="nav-text"> 代码</span></a></li></ol></div>
  320. </div>
  321. <!--/noindex-->
  322. <div class="site-overview-wrap sidebar-panel">
  323. <div class="site-author motion-element" itemprop="author" itemscope itemtype="http://schema.org/Person">
  324. <p class="site-author-name" itemprop="name">Alex</p>
  325. <div class="site-description" itemprop="description"></div>
  326. </div>
  327. <div class="site-state-wrap motion-element">
  328. <nav class="site-state">
  329. <div class="site-state-item site-state-posts">
  330. <a href="/blog/archives">
  331. <span class="site-state-item-count">10</span>
  332. <span class="site-state-item-name">posts</span>
  333. </a>
  334. </div>
  335. <div class="site-state-item site-state-tags">
  336. <a href="/blog/tags/">
  337. <span class="site-state-item-count">4</span>
  338. <span class="site-state-item-name">tags</span></a>
  339. </div>
  340. </nav>
  341. </div>
  342. <div class="links-of-author motion-element">
  343. <span class="links-of-author-item">
  344. <a href="https://github.com/schtonn" title="GitHub → https:&#x2F;&#x2F;github.com&#x2F;schtonn" rel="noopener" target="_blank"><i class="fa fa-fw fa-github"></i>GitHub</a>
  345. </span>
  346. <span class="links-of-author-item">
  347. <a href="mailto:m18519511495@163.com" title="E-Mail → mailto:m18519511495@163.com" rel="noopener" target="_blank"><i class="fa fa-fw fa-envelope"></i>E-Mail</a>
  348. </span>
  349. </div>
  350. <div class="links-of-blogroll motion-element">
  351. <div class="links-of-blogroll-title">
  352. <i class="fa fa-fw fa-link"></i>
  353. Links
  354. </div>
  355. <ul class="links-of-blogroll-list">
  356. <li class="links-of-blogroll-item">
  357. <a href="https://yonghong.github.io/" title="https:&#x2F;&#x2F;yonghong.github.io" rel="noopener" target="_blank">Yonghong</a>
  358. </li>
  359. <li class="links-of-blogroll-item">
  360. <a href="https://source.unsplash.com/random/1600x900" title="https:&#x2F;&#x2F;source.unsplash.com&#x2F;random&#x2F;1600x900" rel="noopener" target="_blank">Background</a>
  361. </li>
  362. </ul>
  363. </div>
  364. </div>
  365. <div id="treefrog" style="text-align: center;margin-top: 18px;">
  366. <object type="application/x-shockwave-flash" style="outline:none;" data="/flash/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>
  367. </div>
  368. </div>
  369. </aside>
  370. <div id="sidebar-dimmer"></div>
  371. </div>
  372. </main>
  373. <footer class="footer">
  374. <div class="footer-inner">
  375. <div class="copyright">
  376. &copy; 2019 –
  377. <span itemprop="copyrightYear">2020</span>
  378. <span class="with-love">
  379. <i class="fa fa-user"></i>
  380. </span>
  381. <span class="author" itemprop="copyrightHolder">Alex Xiang</span>
  382. </div>
  383. </div>
  384. </footer>
  385. </div>
  386. <script src="/blog/lib/anime.min.js"></script>
  387. <script src="//cdn.jsdelivr.net/npm/jquery@3/dist/jquery.min.js"></script>
  388. <script src="//cdn.jsdelivr.net/gh/fancyapps/fancybox@3/dist/jquery.fancybox.min.js"></script>
  389. <script src="//cdn.jsdelivr.net/npm/lozad@1/dist/lozad.min.js"></script>
  390. <script src="/blog/lib/velocity/velocity.min.js"></script>
  391. <script src="/blog/lib/velocity/velocity.ui.min.js"></script>
  392. <script src="/blog/js/utils.js"></script>
  393. <script src="/blog/js/motion.js"></script>
  394. <script src="/blog/js/schemes/muse.js"></script>
  395. <script src="/blog/js/next-boot.js"></script>
  396. <link rel="stylesheet" href="//cdn.jsdelivr.net/npm/katex@0/dist/katex.min.css">
  397. <script>
  398. NexT.utils.loadComments(document.querySelector('#valine-comments'), () => {
  399. NexT.utils.getScript('https://cdn.jsdelivr.net/npm/valine@1/dist/Valine.min.js', () => {
  400. var GUEST = ['nick', 'mail', 'link'];
  401. var guest = 'nick,mail,link';
  402. guest = guest.split(',').filter(item => {
  403. return GUEST.includes(item);
  404. });
  405. new Valine({
  406. el : '#valine-comments',
  407. verify : true,
  408. notify : true,
  409. appId : 'BmologYYnRqCv0SLHDeDdA17-gzGzoHsz',
  410. appKey : 'w9mVebFMdCmY6Nh9vfcBGaGt',
  411. placeholder: "Say something.",
  412. avatar : 'mm',
  413. meta : guest,
  414. pageSize : '10' || 10,
  415. visitor : false,
  416. lang : 'en' || 'zh-cn',
  417. path : location.pathname,
  418. recordIP : true,
  419. serverURLs : ''
  420. });
  421. }, window.Valine);
  422. });
  423. </script>
  424. </body>
  425. </html>