代碼倉庫培訓(xùn)資料(doc33頁)_第1頁
代碼倉庫培訓(xùn)資料(doc33頁)_第2頁
代碼倉庫培訓(xùn)資料(doc33頁)_第3頁
已閱讀5頁,還剩36頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、代碼倉庫目錄:01. 【數(shù)學(xué)方法】矩陣快速冪02. 【數(shù)學(xué)方法】高斯消元( na?ve 版)03. 【數(shù)學(xué)方法】高斯消元( mid 版)04. 【字符串啊】 Manacher 算法(回文串)05.【字符串啊】KMP (字符串匹配)06.【數(shù)據(jù)結(jié)構(gòu)】線段樹(ZKW單點(diǎn)修改)07. 【數(shù)據(jù)結(jié)構(gòu)】線段樹( RMQ)08. 【數(shù)據(jù)結(jié)構(gòu)】線段樹(區(qū)間加 + 賦值)/ !09. 【數(shù)據(jù)結(jié)構(gòu)】 Splay 樹(未完全測試)10. 【數(shù)據(jù)結(jié)構(gòu)】 AVL 樹(平衡樹)11. 【圖論圖論】最小生成樹( prim )12. 【圖論圖論】次小生成樹13. 【圖論圖論】最大流( Dinic )14. 【圖論圖論】 LC

2、A+ 最大生成樹( truck15. 【動(dòng)態(tài)規(guī)劃】背包 01 ,多重,完全矩陣模板#in clude<cstdio>#in clude<cstri ng>#in clude<iostream>usi ngn amespace stdtypedeflong long llcon stintp = 9973;con stintN =13 ;ll n ,mstructmatrix ll aN N;introw , col ;matrix():row (N), col ( N) memset (a, 0,sizeof(a);/?matrix(i ntx ,int y

3、 ): row (x), col ( y)memset(a, 0, sizeof ( a);ll*operator(int x ) return a x;matrixoperator* ( matrix x)matrix tmpJfor ( int i=0; i <= n + 1; i +)for (int j =0; j < =n + 1;j+)tmpi j = 0;for(int k =0; k<= n + 1; k+) voidtmpreturn tmpi j =( tmp i j +Jai k* x kj )% P;operator*=( matrix x)* thi

4、s=* this* x ;matrixoperatorA (ll x )matrix retJfor ( int i=0; i <= n + 1; i +) ret i i = 1;matrix tmp=* this ;for (; x; x>>= 1, tmp *= tmp ) if (x&1)ret *=tmp ; voidreturn retJpri nt()for ( int i=0; i <= n + 1; i +)for (int j =0; j < =n + 1; j +)printf( "%d " , a i j );p

5、uts("");高斯消元,判斷有無解的#in clude<cstdio> #in clude<cmath>#in clude<cstri ng>#in clude<iostream>#in clude<vector>usingn amespacestd ;typedef long long LL con stdouble EPS =1e-6const int N =55 ;structmatrixint a N N;intmatrixmatrixrow , col ;():row ( N), col ( N) me

6、mset (a, 0, sizeof(int x , int y ):row(x), col (y)(a);memset(a, 0, sizeof(a);int * operator ()i =0;(int jvoidpri ntfor ( intforprintfintx ) return a x;i <row ; i +)=0; j <col ; j +)("%d ",a i j );puts ;("");int Gauss(matrix a,int m , int n )int x_cnt= 0;int col,k ;/col為列號,k

7、為行號for ( k = 0, col =0; k<m&&col<n;+ k, + col )intr = k ;/r 為第col列的一個(gè)1for(int i =ki <m;+i ) if (a i col )r =i ;if(! a r col) k -;con ti nue ;if(r != k) for(int i= col ; i <= n;+ i )swap(a ri , ak i );for(int i =k + 1; i <m+ i ) if ( a i col)/消元for (int j= col ; j<=n;+ j ) a

8、 i j A=ak j;(int i =k; i-1; forputs("");<m;+ i ) if ( a i n) return/返回自由元個(gè)數(shù)if高斯消元,求岀一組解的#in elude <iostream>#ineludealgorithm#in elude <estdio>#in elude <estri ng>#in elude <emath>usingn amespaee std ;constint N = 1010 ;eon stdouble EPS =1e-7int m , n;double a N

9、N, x N;int Gaussinteol=0, k =0; /eol為列號,k為行號for(;k<m&&col <n;+ 1k,+ eol )intr = k ;for(int i =k + 1; i<m+ i )if (fabs ( a i eol )> fabs ( a r eolif(fabs ( a r eol)< EPS) k-; eontinueif(r != k) for (inti =eol ; i <= n;+ i )swap(ak i ,ar i);for(int i =k + 1; i<m+ i ) / 消元i

10、f (fabs ( a i eol )> EPS)double t = a i eol / a k eol ;for (int j =eol ; j <= n; j +) a i j -=ai eol = C); for(inti =k ; i <m ;+i ) /無解if(fabs ( a i n)> EPS) return-1;if(k< n ) return n-k ; II自由元個(gè)數(shù)for(int i =n-1; i >= 0; i -)/ 回帶求解double temp = a i n;for(int j =i +1; j<n; +j )te

11、mp-=x j * a i j ;xi=(temp / ai i);(int; /)r=ia km , i ntn )列全為0j * t;Man acher 算法#in clude<cstdio>#in clude<stri ng>#in clude<cstri ng>#in clude<iostream>#i nclude<algorithm>using n amespace std ;const int N =233333 ; 20W/在o(n)時(shí)間內(nèi)算岀以每個(gè)點(diǎn)為中心的最大回文串長度 int Manacher ( string

12、st )int len =st . size ();int *p = new int len +1 ;memset ( p, 0, sizeof ( p);int mx =0, id =0;for ( inti =1; i <= len ; i +)if ( mx>i ) p i = min ( p 2* id - i , mx- i );else p i = 1;while (st i +p i = st i - p i ) p i +; if (i +p i > mx) mx=i +p i ; id =i ;int ma =0;for ( int i =1; i <

13、len ; i +) ma= max( ma, p i ); delete ( p);return ma - 1 ;int main ()/freope n(""fuck.i n","r",stdi n);char st N;while ( scanf ("%s" , st ) str ing st0="$#"for ( int i =0; st i != '0' i +)st0+=st i ; st0 +="#"printf("%dn", Mana

14、cher ( st0 );KMP字符串匹配#in clude<cstdio>#in clude<cstri ng>usingn amespacestd ;typedef long long ll con stint N =100007 ;constint P =1000000007char a N, b N;bool mat N;int next N;ll f N;void getNext ( int m)int i =0, j =- 1;next 0=- 1;while ( i <m)if (j =- 1|bi = bj )if ( b+i != b+ j )

15、next i = jelse n exti = next j ; else j = nextj ;voidKMP (int n , intm)memset ( mat , 0, sizeof ( mat);int i =0, j =0;getNext ( m);while ( i <n&&j <m)if (j =- 11| ai = bj ) i +, j +; else j =next j ;if (! i &&! j ) break ;if (j = m)mat i = 1;/prin tf("mat%dgetn",i);j=

16、next j ;線段樹(ZKW大法)#in clude<cstdio> #in clude<cstri ng>#in clude<iostream>#i nclude<algorithm>using n amespace std ;con stint INF =0x3f3f3f3f;constint N =3000100 ;struct lin etree #define lc (t<<1)#define rc (t<<1A1)int mi N, M;inlinevoid build (int n )M = 1 ; whi

17、le ( M<n) M<<= 1 ; M -; memset ( mi , INF , sizeof ( mi );&mi i ); mi rc );for( int i =1 +M; i <=n + M i +) scanf ("%d",for( int t =M; t >= 1 ; t -) mi t = min ( mi lc ,void change (int t , int x )for ( mi t += M= x, t >>= 1; t ; t >>= 1)mi t = min ( mi lc ,

18、mi rc );int query ( int l , int r )int ans = INF ;for(l+= MM , r +=M+1; l a r a1; l >>= 1, r>>= 1)if( l &1) ans=min ( ans, mi l a 1 );if( r &1) ans=min ( ans, mi r a 1 );return ans ;T;int mai n ()int n , q, ord , x, y;for (; scanf ("%d",& n);)T . build ( n);for ( sc

19、anf ("%d",& q); q-;)scanf( "%d%d%d",& ord,& x,& y);if (ord ) T. cha nge ( x, y);else printf ("%dn", T. query ( x, y);線段樹(RMQ#in clude<cstdio>#in clude<cstri ng>#in clude<iostream>#i nclude<algorithm> usi ngn amespace stdcon stint

20、N =600100 ;int n ,ans , m, a N;structnodeintl , r ,id ;node() node(intx , int y , intz ) l =x;r =y; id=z;bN,c N;inlineboolcmp1 (node a,node b)returnainlineboolcmp2 ( node a,node b)returna .structlin etreeconstl <b.r < INF =0x3f3f3f3fl ;r;#defi ne lc (t<<1)#define rc (t<<1A1)#d

21、efi ne mid (lt+rt>>1) int l N, r N, ma N, inlinemi N,void build (int n )M ta N,tiN;M =1memsetmemsetwhile ( M<n) M«= 1 ; M -;(ma, 0 , sizeof(mi , INF , sizeof(ma);(mi );memsetmemsetforfor(ti(int(int(ta ,0 , sizeof,INF , sizeofi =1 +M; i <= M* 2+1 ; i +) l i t =M; t >= 1 ; t -) l t

22、 = l lc(ta );(ti );=,r i = rt=i - M ; r rc ; inlinevoidif(t >M)down ( int t ) return;/leaf nodemamatalcrclc=max( ma max( ma max (ta lcrclc,tatatat);t);t);tatarc=tmax (ta 0;rc,tat);mimitititit=min ( mi lc ,tit);=min ( mi rc ,tit);=min (ti lc ,tit);=min (ti rc ,tit);=INF ;lcrclcrcinlinevoid mai nta

23、in(int t )mat = max( ma Ic ,ma rc );mit = min ( mi Ic ,mi rc );inlinevoid tag ( int t,int x )mat = max( ma t , x);mit = min ( mi t , x);tat = max( ta t , x);tit = min (ti t , x);voidchange (int t , intL , i nt R , i nt x )if(L<= l t && r t <= R) tag (t , x); return ; /indow n(t);if(L&l

24、t;= mid ) change(lc , L, R, x);if(mid < R ) change(rc , L, R, x);maintan(t);voidquery ( int t )if(t >M) /leaf nodebt - M= c t - M=node ( mi t , ma t , t - M);return;dow n(t);query(lc );query(rc );maintan(t);T;線段樹(區(qū)間加+賦值)#in clude<cstdio>#in clude<cstri ng>#in clude<iostream>

25、#i nclude<algorithm>usingn amespace std;constint N =260000 ;int n , m;structlin etree#define lc (t<<1)#define rc (t<<1A1)#define mid (lt+rt>>1)Set N;int l N, r N, M tag N, sum N, len N,inline void build (int n )M = 1 ; while ( M<n) M«= 1 ; M -; /get M memset( sum,0,si

26、zeof(sum);memset(tag ,0,sizeof(tag );memset( Set ,0,sizeof(Set );for ( int i =1 +M; i <=M* 2+1 ; i +) /leafif ( i <= n + M) scanf ("%d",& sum i );li = r i :=i-M ;leni = 1;for(int t =M; t >=1;t-)/fatherssumt = sum lc+sum rc ;lt = l lc , rt=r rc ;lent = len lc+len rc ;inlinevoid

27、 down ( intt)if(t >M) Set t =tagt=:0; returnif ( Set t );/leaf nodesumlc = Set t * len lc ;sumrc = Set t * len rc ;Setlc = Set t;Setrc = Set t ;Sett = 0;taglc = tag rc = 0;if(tag t)sumlc += tag t * len lc ;sumrc += tag t * len rc ;taglc += tag t ;tagrc += tag t ;tagt = 0;inlinevoid _tag (int t ,

28、int x )sumt += x* len t ;tagt += x;inlinevoid _set (int t , int x )sumt = x* len t ;Sett = x;tagt= 0;void change(int t , int L , int R , int x)if(L<=l t&& r t <= R) _tag (t , x);returndow n(t);if(L<= mid ) change (lc , L, R, x);if(mid < R ) change (rc , L, R, x);sumt = sum lc + s

29、um rc ;void set (int t , int L , int R , int x )if(L<=l t&& r t <= R) _set (t , x);returndow n(t);if(L<= mid ) set ( lc , L, R, x);if(mid < R ) set ( rc , L, R, x);sumt = sum lc + sum rc ;int query ( int t , intL , intR )if(L<= l t && r t <= R) return sumt;dow n(t);

30、intans = 0;if(L<= mid ) ans += query ( lc , L, R);if(mid < R ) ans += query ( rc , L, R);; inreturnansT;Splay-Tree #in clude<cstdio>#i nclude<algorithm> using n amespace std struct Node intkey;/sizeNode;*,*r ,* f;left,right,fatherclass SplayTree public :voidInit() rt= NULL ;voidZag

31、(Node*x) /left rotateNode* y = x-> f ; /y is the father of xy->r=x ->l ;if(x-> l ) x-> l -> f = y ; /if x has left childx->f=y-> fJif(y-> f)/y is not rootif(y=y -> f -> l ) y-> f -> l=x; /y if left childelse y-> f -> r =x; /y is right childy->f =x; x -

32、> l =y ;voidZig(Node*x) /right rotateNode* y = x-> f ; /y is the father of xy->l=x ->r ;if(x-> r) x-> r -> f =y;x->f=y ->f ;if(y-> f)if(y=y -> f -> l ) y-> f -> l=x;else y-> f -> r =x ;y->f =x;x->r =y;voidSplay(Node * x)whihe(x->f)Nc)de*p=x-&g

33、t; f ;if(! p-> f )if(x= p-> l ) Zig ( x);elseZag ( x); elsef (x = p-> l )if(p= p-> f -> l ) Zig(p); Zig (x);else Zig ( x); Zag (x); elsex=p->rif ( p= p-> f -> r)Zag ( p); Zag ( x);else Zag ( x); Zig(x);rt=x;Node* Find ( int x )Node* T=rt ;while (T)if ( T-> key = x) Splay(T

34、); return T ;else if ( x<T-> key ) T=T-> l ;else T =T-> r ;return T ;voidInsert(int x )Node*T=rt ,* fa =NULL;while (T)fa=T;if ( x<T-> key ) T=T-> l>else if ( x>T-> key ) T=T-> r ;elsereturn; /two the same keysT=(Node *) malloc ( sizeof(Node);T-> key =x;T-> l =T

35、-> r =NULL;T-> f =fa ;if(fa )if (fa -> key >x) fa -> l=T;else fa -> r =T;Splay(T);voidDelete (int x )Node*T=Find (x);if(NULL =T) return;/errorrt= Join ( T-> l , T-> r);Node* Max num ( Node * t )Node*T=t ;while( T-> r) T=T-> r;Splay(T);return T ;Node * Minnum ( Node * t

36、)Node* T=t ;while (T-> l ) T=T-> l ;Splay(T);return T ;Node* Last ( int x )Node*T=Find (x);T= T-> l ;return( Maxnum ( T);Node* Next ( int x )Node*T=Find (x);T= T-> r ;return( Minnum ( T);Node* Join ( Node * t1 , Node * t2 )if ( NULL =t1 ) returnt2 ;if ( NULL =t2 ) returnt1 ;Node* T=Maxnu

37、m (t1 );T -> l =t2 ;return T ;void Split ( int x , Node *& t1 , Node *& t2 ) Node*T=Find (x);t1 =T-> l ; t2 =T-> r;void In order( Node * T)if ( NULL=T) return ;Inorder( T-> l );printf("%d->" , T-> key );Inorder( T-> r);void _Delete () Delete ( rt );void Delete

38、(Node *T)if(NULL=T) returnDelete(T-> l );Delete(T-> r);free(T);private :Node;* rt ; /rootAVL樹codevs1285莯? ?/by cww97#in clude<cstdio>#in clude<iostream>#i nclude<algorithm>#defi ne INF Oxfffffff#defi ne BASE 1000000using n amespace std ;int ans =0;struct Node int x , bf , h;

39、/bf=balanee factor,h=height Node * l ,* r ;; class AVLTree public :voidInit () rt=NULL; intH ( Node*T)return(T=NULL)? 0: T-> h;intBF ( Node*l ,Node* r) /get balanee factorif (NULL=l && NULL=r) return 0;elseif(NULL = l )returnelseif(NULL = r )returnreturnl-> h - r -> h;-r -> h; l

40、-> h;Node * Lrorate ( Node * a) /left rorateNode * b;b=a-> r ;a->r =b-> lJb->l =a;a->h = max (H( a->l),H( a->r)+ 1b->h = max (H( b->l),H( b->r)+ 1a->bf =BF(a -> l ,a ->r);b->bf =BF(b-> l ,b->r);return bNode * Rrorate ( Node * a) /right rorateNode *

41、b;b=a -> l ;a-> l =b-> r ;b-> r =a;a-> h = max ( H( a-> l ), H( a -> r)+ 1;b-> h = max ( H( b-> l ), H( b -> r)+ 1;a-> bf =BF( a-> l , a-> r);b-> bf =BF( b-> l , b-> r);return b ;Node* LRrorate ( Node * a) /left then righta-> l = Lrorate( a-> l )

42、;Node * c;c = Rrorate (a);return c ;Node * RLrorate ( Node * a) /right then left a -> r = Rrorate ( a-> r);Node * c;c = Lrorate (a);return c ;voidInsert(int x ) _lnsert( rt , x);void_lnsert( Node *& T, int x )if(NULL=T)T=(Node *) malloc ( sizeof(Node);T-> x = x;T-> bf =0; T-> h =

43、1 ;T-> l =T-> r =NULL; ifreturn;(x < T -> x) _Insert(T-> l , x);elseif ( x > T -> x) _Insert(T-> r , x);elsereturn; /error :the same yT-> h = max ( H( T-> l ), H( T-> r)+ 1; maintainT-> bf =BF( T-> l , T-> r);if (T->bf> 1 II T->bf< -1)/not bala n

44、eedif(T-> bf >0&& T -> l-> bf> 0) T=Rrorate(T);elseif(T-> bf<0&& T ->r -> bf< 0) T=Lrorate(T);elseif(T-> bf>0&& T ->l -> bf< 0) T=LRrorate(T);elseif(T-> bf<0&& T ->r -> bf> 0) T=RLrorate(T);void GetPet (int x

45、 ) /get pet or person if ( NULL = rt ) return ; int small =0, large =INF ;pri ntf("x=%dn",x);int flag if ( FindJ(rt , x, small , large )printf("find %dn", x);_Delete(rt , x); elseif(small = 0) flag =1;elseif(large = INF ) flag =0;elseif(large - x<x- small ) flagelseflag=0;if (

46、!flag) /choose large_Delete(rt , small );ans=(ans +x- small )% BASE; else_Delete(rt , large );ans=(ans +large - x)% BASE;bool Findif(Node *T, int(NULL=T) returnx , int &small , int &large )0;ififlarge(x =T-> x) return (x<T-> x)= min (largeFind ( T->return else smallreturn= max( s

47、mallFind ( T->1;,T-> x);l , x, small , large,T-> x);r, x, small , large););(Node *& T,int x )void Deleteif ( NULL=T) return(x < T -> x)(T-> l , x);bf =BF( T-> l , T-> r);(T-> bf <- 1)if ( 1 = T-> r -> bf ) T = RLrorate else T = Lrorate ( T); bf=O or -1ifDelete

48、->ify at left(T); else if (x > T -> x) y at right_Delete(T-> r , x);T->bf =BF( T-> l , T-> r);if(T-> bf >1)if(-1 =T-> l -> bf ) T=LRrorate ( T)elseT = Rrorate ( T); bf=O or 1 else/here is xif(T-> l &&T-> r) /left &&rightNode* t =T-> l ;while(

49、t -> r) t =t -> r ;T->x =t -> x ;_Delete(T-> l , t -> x);T->bf =BF( T-> l , T-> r);if(T-> bf <- 1)if ( 1 = T-> r -> bf ) T=RLrorate ielse T = Lrorate ( T); bf=O or -1 else/left | rightNode*t =T;if(T-> l ) T=T-> l ;elseif (T-> r) T=T-> r;else free ( T); T=NULL;if(T) free (t );Debug,you will not n eed it at this problemvoid show () In Order ( rt ); puts (&

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論