Poj3261 Milk Patterns

題目傳送門

題意:對一個字符串求一個最長的子串使得它至少出現k次

額,因為這個題目呢,他的字符集非常大(100W)

所以直接用SAM是不行了,我們考慮用離散化+SA,讓后就可以分塊rmq了

當然這樣很麻煩,我們還是用SAM,但是兒子集合用map來存,這樣空間就是O(n)的,時間多了一個log

#pragma GCC opitmize("O3")
#pragma G++ opitmize("O3")
#include<map>
#include<stdio.h>
#include<string.h>
#include<algorithm>
#define N 40005
using namespace std;
map<int,int> s[N];
int mx[N],sz[N],f[N],ans=0;
int n,m,lst=1,cnt=1,v[N],r[N];
inline int extend(int c){int p=lst,np=lst=++cnt,q,nq;mx[np]=mx[p]+1; sz[np]=1;for(;p&&!s[p][c];p=f[p]) s[p][c]=np;if(!p) return f[np]=1;q=s[p][c];if(mx[q]==mx[p]+1) f[np]=q;else{nq=++cnt;mx[nq]=mx[p]+1;f[nq]=f[q]; f[q]=f[np]=nq;s[nq]=s[q];for(;p&&s[p][c]==q;p=f[p]) s[p][c]=nq;}
}
int main(){scanf("%d%d",&n,&m);for(int x,i=1;i<=n;++i,extend(x)) scanf("%d",&x);for(int i=1;i<=cnt;++i) ++v[mx[i]];for(int i=1;i<=n;++i) v[i]+=v[i-1];for(int i=cnt;i;--i) r[v[mx[i]]--]=i;for(int i=cnt;i;--i){sz[f[r[i]]]+=sz[r[i]];if(sz[r[i]]>=m) ans=max(ans,mx[r[i]]);}printf("%d\n",ans);
}

轉載于:https://www.cnblogs.com/Extended-Ash/p/9477186.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/251468.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/251468.shtml
英文地址,請注明出處:http://en.pswp.cn/news/251468.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

html5 --- 使用canvas畫一個漸變矩形

我們希望得到如下效果: 首先準備畫布 // HTML <canvas width"500" height"375" id "a"> </canvas>// JS // 獲取畫布的DOM元素 var a_canvas document.getElementById("1"); // 獲取畫布的上下文元素(之后,就可以使用…

PHP優化與提升

一。十個不錯的建議1.使用 ip2long() 和 long2ip() 函數來把 IP 地址轉化成整型存儲到數據庫里。這種方法把存儲空間降到了接近四分之一&#xff08;char(15) 的 15 個字節對整形的 4 個字節&#xff09;&#xff0c;計算一個特定的地址是不是在一個區段內頁更簡單了&#xff0…

Servlet詳解之兩個init方法的作用

在Servlet中 javax.servlet.GenericServlet類 繼承自java.lang.Object 實現了Serializable,&#xff0c;servlet &#xff0c;ServletConfig 三個接口 被繼承對象javax.servlet.http.HttpServlet &#xff08;這是我們常用的一個類&#xff09; 但仔細看GenericServlet的API&am…

vue --- 使用vue在html上顯示當前時間

希望如下效果(時間按秒鐘更新) 導入Vue依賴的CDN <script src"https://unpkg.com/vue/dist/vue.min.js"> </script>創建視圖 <div id"app">{{date}}</div>Model <script>var app new Vue({el: "app",data: …

namespace 或The content of element type mapper must match EMPTY

必須為元素類型 "mapper" 聲明屬性 "namespace" 或The content of element type "mapper" must match "EMPTY" <?xml version"1.0" encoding"UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org/…

EAS WebService部署

1、創建 facade ,設置好接口及參數、返回信息; 2、代碼&#xff1a;元數據打包部署到服務器; 3、然后修改配置文件&#xff1a; 將本地開發環境生成的.wsdd文件拷貝到eas\server\deploy\eas.ear的web.war下的WEB-INF目錄下&#xff0c;再將.wsdd文件中的<service></se…

vue --- 購物車頁面

下面我看開始自己寫一個購物車的頁面. 我們希望得到如下的效果: 說明: 購買數量最小為0購買數量變化時,對應的總價隨之變化點擊移除操作對應的商品會移除掉,總價隨之改變每個商品作為一個list表的一個對象每個對象,包含id、name、price、count等屬性 index.html (整體代碼最…

Javascript阻止表單提交

Javascript阻止表單提交 Html 1.<form name"loginForm" action"login.aspx" method"post"> 2. <button type"submit" value"Submit" id"submit">Submit</button> 3.</form> Js …

XML CDATA的作用

操作XML文件時&#xff0c;如果允許用戶輸入內容&#xff0c;例如∶"< "、">"、"/"、""等&#xff0c;當生成XML時&#xff0c;會破壞了XML結構&#xff0c;使數據中斷。 這就要用XML CDATA 在XML文檔中的所有文本都會被解析器解…

vue --- 從模塊從父元素獲取數據

vue的精彩之處在于其組件的可復用性.下面談談組件(component)如何從父元素獲取數據 模塊引用 首先說說,如何引用模塊 <div id"app"><my-component ></my-component> </div> <script src“unpkg.com/vue/dist/vue.min.js”> </…

前端知識總結(一)

1、用原生JS實現forEach if(!Array.prototype.forEach) {Array.prototype.forEach function(fn, context) {var context arguments[1];if(typeof fn ! "function") {throw new TypeError(fn "is not a function");}for(var i 0; i < this.length; …

廣播風暴

能夠抑制網絡風暴的是&#xff1f;A中斷器 B集線器 C網橋 D路由器 答案D解析&#xff1a;&#xff08;1&#xff09;廣播風暴&#xff1f;一個數據幀或包被傳輸到本地網段上的每個節點就是廣播&#xff1b;由于網絡拓撲的設計和連接問題&#xff0c;或其他原因導致廣播在網段內…

java getClass()

Java反射學習 所謂反射&#xff0c;可以理解為在運行時期獲取對象類型信息的操作。傳統的編程方法要求程序員在編譯階段決定使用的類型&#xff0c;但是在反射的幫助下&#xff0c;編程人員可以動態獲取這些信息&#xff0c;從而編寫更加具有可移植性的代碼。嚴格地說&#xff…

vue --- 模塊從子組件獲取數據

先看個一般的例子: // 我們需要將信息從子組件傳遞給父組件,(有可能不止一條信息,因此)肯定需要一個標識,這個標識放在$emit里面(js),在dom中通過來關聯父元素。如下:<div id "app"><transfer connect"sayConnect" build"sayBuild"&g…

mySql配置在nodejs中使用

mySql安裝完成后&#xff0c;配置鏈接nodejs項目中的數據庫。 1、測試是否安裝成功。 2、use nodejs使用nodejs 3、設置數據源 5、exit 轉載于:https://www.cnblogs.com/zhxzh/p/9244996.html

轉,jquery中attr和prop的區別

https://www.cnblogs.com/Showshare/p/different-between-attr-and-prop.html 像checkbox&#xff0c;radio和select這樣的元素&#xff0c;選中屬性對應“checked”和“selected”&#xff0c;這些也屬于固有屬性&#xff0c;因此需要使用prop方法去操作才能獲得正確的結果。 …

前端知識總結(二)

33、閉包 閉包的概念 上一節代碼中的f2函數&#xff0c;就是閉包。 各種專業文獻上的"閉包"&#xff08;closure&#xff09;定義非常抽象&#xff0c;很難看懂。我的理解是&#xff0c;閉包就是能夠讀取其他函數內部變量的函數。 由于在Javascript語言中&#x…

javascript --- 實現Ajax的代碼

直接上代碼,(前幾天項目出差部署去叻) const ajax function (options {}) {option.type (options.type || GET).toUpperCase();let data [];for(let i in options.data) {data.push(encodeURIComponent(i) encodeURIComponent (options.data[i]));}data data.join(&am…

[Spark]-RDD詳解之變量操作

RDD的操作 1.1 概述 RDD整體包含兩大類操作 transformation 從現有中創建一個新的數據集 action 在對數據集做一定程度的計算后將結果返回 對于所有的transformation,都是Lazy的,也就是說它不會立即執行,只是單純的記住怎么樣從原來的數據集進行轉換的邏輯而已,它僅在某一個計算…

前端知識總結(三)

51、啟動GNU加速 硬件加速的工作原理 瀏覽器接收到一個頁面之后&#xff0c;將html解析成DOM樹&#xff0c;瀏覽器解析渲染「html」的過程 按著一定的規則執行&#xff0c;DOM樹和CSS樹結合后構成瀏覽器形成頁面的 渲染樹 ; 渲染樹中包含大量的渲染元素&#xff0c;每一個元素…