KEMBAR78
Competitive Programming Notebook: Joao Carreira 2010 | PDF | Theoretical Computer Science | Computer Programming
0% found this document useful (0 votes)
148 views21 pages

Competitive Programming Notebook: Joao Carreira 2010

This document contains a concise summary of algorithms and data structures for competitive programming. It includes sections on strings, dynamic programming, graphs, geometric algorithms, numerical algorithms, sorting/searching, and implementations of algorithms like KMP string matching, range minimum query, Dijkstra's algorithm, and more. The goal is to provide Joao Carreira's team with efficient solutions to practice problems.

Uploaded by

Anmol Agarwal
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
148 views21 pages

Competitive Programming Notebook: Joao Carreira 2010

This document contains a concise summary of algorithms and data structures for competitive programming. It includes sections on strings, dynamic programming, graphs, geometric algorithms, numerical algorithms, sorting/searching, and implementations of algorithms like KMP string matching, range minimum query, Dijkstra's algorithm, and more. The goal is to provide Joao Carreira's team with efficient solutions to practice problems.

Uploaded by

Anmol Agarwal
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 21

Competitive Programming Notebook

Joao Carreira
2010

Contents 4.10 Detecting Bridges . . . . . . . . . . . . . . . . . 12


4.11 Finding a Loop in a Linked List O(n) . . . . . 13
1 Introduction 2 4.12 Tree diameter . . . . . . . . . . . . . . . . . . . 13
4.13 Union Find . . . . . . . . . . . . . . . . . . . . 13
2 Strings 2 4.14 Edmonds Karp . . . . . . . . . . . . . . . . . . 13
2.1 Knuth-Morris-Pratt (KMP) . . . . . . . . . . . 2 4.15 Ford Fulkerson . . . . . . . . . . . . . . . . . . 14
2.2 Range Minimum Query . . . . . . . . . . . . . 2 4.16 Widest path problem . . . . . . . . . . . . . . . 14
2.3 Nth Permutation . . . . . . . . . . . . . . . . . 2
5 Geometrical Algorithms 14
3 Dynamic Programming 3 5.1 Circle . . . . . . . . . . . . . . . . . . . . . . . 14
3.1 Longest Common Subsequence (LCS) . . . . . 3 5.2 Triangle’s medians . . . . . . . . . . . . . . . . 14
3.2 Longest Increasing Subsequence (LIS) . . . . . 3 5.3 Heron’s formula . . . . . . . . . . . . . . . . . . 15
3.2.1 O(n2 ) version . . . . . . . . . . . . . . . 3 5.4 Dot Product . . . . . . . . . . . . . . . . . . . . 15
3.2.2 O(n log n) version . . . . . . . . . . . . 3 5.5 Cross Product . . . . . . . . . . . . . . . . . . . 15
3.3 MCM (Matrix Chain Multiplication) . . . . . . 4 5.6 Point on segment . . . . . . . . . . . . . . . . . 15
3.4 Knapsack . . . . . . . . . . . . . . . . . . . . . 4 5.7 Intersection of segments . . . . . . . . . . . . . 15
3.5 Counting Change . . . . . . . . . . . . . . . . . 4 5.8 Position of point in relation to line . . . . . . . 15
3.6 Coin Changing . . . . . . . . . . . . . . . . . . 4 5.9 Distance between point and line/segment . . . 15
3.7 Biggest Sum . . . . . . . . . . . . . . . . . . . . 5 5.10 Polygon Area . . . . . . . . . . . . . . . . . . . 16
3.8 Edit Distance . . . . . . . . . . . . . . . . . . . 5 5.11 Convex Hull . . . . . . . . . . . . . . . . . . . . 16
3.9 Integer Partitions . . . . . . . . . . . . . . . . . 5 5.12 Closest pair of points . . . . . . . . . . . . . . . 16
3.10 Box Stacking . . . . . . . . . . . . . . . . . . . 5 5.13 Test if point is inside a polygon . . . . . . . . . 17
3.11 Building Bridges . . . . . . . . . . . . . . . . . 6 5.14 Circle from 3 points . . . . . . . . . . . . . . . 17
3.12 Partition Problem . . . . . . . . . . . . . . . . 6
3.13 Balanced Partition . . . . . . . . . . . . . . . . 6 6 Numerical 17
6.1 Check if float is an integer . . . . . . . . . . . . 17
4 Graphs 7 6.1.1 Big Mod . . . . . . . . . . . . . . . . . . 17
4.1 Heap . . . . . . . . . . . . . . . . . . . . . . . . 7 6.2 Triangle area . . . . . . . . . . . . . . . . . . . 17
4.2 Find an Eulerian Path . . . . . . . . . . . . . . 8 6.3 Heron’s formula . . . . . . . . . . . . . . . . . . 17
4.3 Breadth First Search . . . . . . . . . . . . . . . 8 6.4 Choose . . . . . . . . . . . . . . . . . . . . . . . 17
4.4 DFS/TopSort . . . . . . . . . . . . . . . . . . . 9 6.5 Modulo: . . . . . . . . . . . . . . . . . . . . . . 18
4.5 Prim’s Algorithm . . . . . . . . . . . . . . . . . 9 6.6 LCM / GCD . . . . . . . . . . . . . . . . . . . 18
4.5.1 Naive version . . . . . . . . . . . . . . . 9 6.7 Base conversion . . . . . . . . . . . . . . . . . . 18
4.5.2 Set version . . . . . . . . . . . . . . . . 10 6.8 Horner’s Rule . . . . . . . . . . . . . . . . . . . 18
4.6 Dijkstra . . . . . . . . . . . . . . . . . . . . . . 10 6.9 Matrix Multiplication . . . . . . . . . . . . . . 18
4.6.1 Naive version . . . . . . . . . . . . . . . 10 6.10 Long Arithmetic . . . . . . . . . . . . . . . . . 18
4.6.2 Set version . . . . . . . . . . . . . . . . 10 6.11 Infix para Postfix . . . . . . . . . . . . . . . . . 19
4.7 Kth Shortest Paths O(Km) . . . . . . . . . . . 11 6.12 Calculate Postfix expression . . . . . . . . . . . 20
4.8 Floyd-Warshall O(n3 ) . . . . . . . . . . . . . . 11 6.13 Postfix to Infix . . . . . . . . . . . . . . . . . . 20
4.9 Bellman-Ford . . . . . . . . . . . . . . . . . . . 12 6.14 Matrix Multiplication . . . . . . . . . . . . . . 20

1
6.15 Catalan Numbers . . . . . . . . . . . . . . . . . 20 << ”Match a t pos : ”
6.16 Fibonnaci . . . . . . . . . . . . . . . . . . . . . 20 << ( i − m + 1 )
<< s t d : : e n d l ;
7 Sorting / Search 21 }
7.1 Counting Sort . . . . . . . . . . . . . . . . . . . 21 }
7.2 Binary Search - Lower bound . . . . . . . . . . 21 }
7.3 Binary Search - Upper bound . . . . . . . . . . 21
2.2 Range Minimum Query
1 Introduction int main ( ) {
int N, Q, i , j , k ;
This document was written to be used in programming com-
petitions by my team: HammerHappy. Conciseness (not clar- s c a n f ( ”%d %d” , &N, &Q) ;
ity) was the priority.
f o r ( i = 0 ; i < N; i ++)
s c a n f ( ”%d” , &n [ i ] ) ;
2 Strings
f o r ( i = 0 ; i < N; i ++)
2.1 Knuth-Morris-Pratt (KMP) m[ i ] [ 0 ] = M[ i ] [ 0 ] = n [ i ] ;

s t d : : v e c t o r <int> c o m p u t e p r e f i x ( f o r ( i =1; ( 1 << i ) <= N; i ++) {


const s t r i n g& p ) { f o r ( j = 0 ; j + ( 1 << i ) − 1 < N; j ++) {
int m = p . s i z e ( ) ; m[ j ] [ i ] = min (m[ j ] [ i − 1 ] , m[ j +
s t d : : v e c t o r <int> p i (m) ; ( 1 << ( i − 1 ) ) ] [ i − 1 ] ) ;
pi [ 0 ] = 0; M[ j ] [ i ] = max(M[ j ] [ i − 1 ] , M[ j +
( 1 << ( i − 1 ) ) ] [ i − 1 ] ) ;
int k = 0 ; }
for ( int q = 1 ; q < m; q++) { }
while ( k > 0 && p [ k ] != p [ q ] )
k = pi [ k −1]; f o r ( k = 0 ; k < Q; k++) {
s c a n f ( ”%d %d” ,& i ,& j ) ;
i f ( p [ k ] == p [ q ] )
i −−;
k++;
j −−;
pi [ q ] = k ;
int t , p ;
}
t = ( int ) ( l o g ( j − i + 1 ) / l o g ( 2 ) ) ;
return p i ; p = 1 << t ;
} p r i n t f ( ”%d\n” , max(M[ i ] [ t ] ,
M[ j − p + 1 ] [ t ] )
void kmp match ( const s t r i n g& s , − min (m[ i ] [ t ] , m[ j − p + 1 ] [ t ] ) ) ;
const s t r i n g& p ) { }
s t d : : v e c t o r <int> p i = c o m p u t e p r e f i x ( p ) ; return 0 ;
int q = 0 ; }
int n = s . s i z e ( ) ;
int m = p . s i z e ( ) ; M [i][j] = max(M [i][j − 1], M [i + 2j−1 ][j − 1])

for ( int i = 0 ; i < n ; i ++) { RM QA (i, j) = max(M [i][k], M [j − 2k + 1][k])


while ( q > 0 && p [ q ] != s [ i ] )
q = pi [ q − 1 ] ; 2.3 Nth Permutation
i f ( p [ q ] == s [ i ] )
q++; /∗ ∗
i f ( q == m) { ∗ Computes k t h (0 t o s . s i z e ( ) ! − 1) p e r m u t a t i o n
std : : cout ∗ of string s

2
∗/ int LCSString ( int L [MAX] [MAX] ) {
std : : s t r i n g nth permutation ( uin t6 4 t k , int i , j ;
const s t d : : s t r i n g &s ) { i = j = 0;
uint64 t factorial = 1; while ( i < m && j < n ) {
for ( u i n t 6 4 t i = 1 ; i <= s . s i z e ( ) ; ++i ) { i f (A[ i ] == B [ j ] ) {
f a c t o r i a l ∗= i ; // p u t A[ i ] a t t h e end
} // o f s o l u t i o n s t r i n g
i ++; j ++;
std : : s t r i n g s copy = s ; }
std : : s t r i n g res ; i f (L [ i + 1 ] [ j ] >= L [ i ] [ j + 1 ] ) i ++;
for ( u i n t 6 4 t j = 0 ; j < s . s i z e ( ) ; ++j ) { e l s e j ++;
// compute how many p e r m u t a t i o n s }
// on t h e r e s t o f t h e }
// s t r i n g s [ j + 1 . . s . s i z e ( ) − 1 ]
f a c t o r i a l /= s . s i z e ( ) − j ; 3.2 Longest Increasing Subsequence (LIS)
3.2.1 O(n2 ) version
// s t o r e c h a r a c t e r
uint64 t l = k / factorial ; int pred [ MAX SIZE ] , l a s t i ;
r e s += s c o p y [ l ] ; int LIS ( int C [ ] , int n ) {
int s [ MAX SIZE ] , max = INT MIN ;
// remove a l r e a d y used c h a r a c t e r f o r ( int i = 1 ; i < n ; i ++) {
s copy . erase ( s copy . begin () + l ) ; f o r ( int j = 0 ; j < i ; i ++) {
i f (C [ i ] > C [ j ] && s [ i ] <= s [ j ] ) {
// compute new v a l u e o f k pred [ i ] = j ;
k = k % factorial ; i f ( ( s [ i ] = s [ j ] + 1 ) > max)
} lasti = i ;
return r e s ; max = s [ i ] ;
} }
}
3 Dynamic Programming }
return max ;
3.1 Longest Common Subsequence (LCS) }
int L [MAX] [MAX] = { { 0 } } ; void P r i n t L I S ( ) {
int LCS( char A [ ] , char B [ ] ) { int i , j , aux [ MAX SIZE ] ;
// m = s t r l e n (A) f o r ( j = max − 1 , i = l a s t i ; j >= 0 ; j −−) {
// n = s t r l e n (B) aux [ j ] = C [ i ] ;
for ( int i = m; i >= 0 ; i −−) {} i = pred [ i ] ;
fo r ( int j = n ; j >= 0 ; j −−) { }
i f ( ! A[ i ] | | ! B [ j ] )
L[ i ] [ j ] = 0; f o r ( j = 0 ; j < max ; j ++)
e l s e i f (A[ i ] == B [ j ] ) p r i n t f ( ‘ ‘% d\n ’ ’ , aux [ j ] ) ;
L[ i ] [ j ] = 1 + L[ i + 1][ j + 1]; }
e l s e L [ i ] [ j ] = max(L [ i + 1 ] [ j ] ,
L[ i ] [ j + 1]); 3.2.2 O(n log n) version
}
} int a , num [ 1 2 0 0 0 0 ] , n , ans [ 1 2 0 0 0 0 ] , s z ;
return L [ 0 ] [ 0 ] ;
} while ( s c a n f ( ”%d” ,&n ) == 1 ) {
f o r ( a = 0 ; a < n ; a++)

3
s c a n f ( ”%d” , &num [ a ] ) ; // p u t one z e r o i n w e i g h t and v a l u e ;
sz = 0; // e . g .
for ( a = 0 ; a < n ; a++) { // w e i g h t ={ >0 < ,3 ,4 ,5}
int ∗ i t = lower bound ( // v a l u e ={ >0 < ,3 ,4 ,5 ,6};
ans , ans + sz , num [ a ] ) ; int knapsack ( int items , int W,
i f ( i t != ans + s z ) ∗ i t = num [ a ] ; int v a l u e [ ] , int w e i g h t [ ] ) {
e l s e ans [ s z ++] = num [ a ] ; f o r ( int i = 1 ; i <= i t e m s ; i ++) {
} f o r ( int j = 0 ; j <= W; j ++) {
p r i n t f ( ”%d\n” , s z ) ; i f ( w e i g h t [ i ] <= j ) {
} i f ( v a l u e [ i ] + n [ i − 1 ] [ j −w e i g h t [ i ] ]
> n [ i −1][ j ] ) {
3.3 MCM (Matrix Chain Multiplication) n [ i ] [ j ] = value [ i ] +
n [ i − 1 ] [ j −w e i g h t [ i ] ] ;
void mcm( ) {
} else {
int i , j , n = 3 ;
n [ i ] [ j ]=n [ i − 1 ] [ j ] ;
for ( i = 0 ; i < n ; i ++)
}
m[ i ] [ i ] = 0 ;
} e l s e n [ i ] [ j ]=n [ i − 1 ] [ j ] ;
}
for ( i = n − 1 ; i >= 0 ; i −−)
}
fo r ( j = i + 1 ; j <= n ; j ++)
return n [ i t e m s ] [W] ;
m[ i ] [ j ] = c a l c ( i , j ) ;
}
}
void p r i n t s e q u e n c e ( int items , int W, int w e i g h t [ ] ) {
int c a l c ( int i , int j ) { int i = items , k = W;
int r e s = INT MAX ; while ( i > 0 && k > 0 ) {
for ( k = i ; k < j ; k++) { i f ( n [ i ] [ k ] != n [ i − 1 ] [ k ] ) {
p r i n t f ( ” item %d i s i n \n” , i ) ;
tmp = m[ i ] [ k ] + m[ k + 1 ] [ j ]+ k = k−w e i g h t [ i − 1 ] ;
Li ne [ i ] ∗ Col [ k ] ∗ Col [ j ] ; }
i f ( tmp < r e s ) { i −−;
r e s = tmp ; }
s [ i ][ j ] = k; }
} 3.5 Counting Change
}
return r e s ; int c o i n s [ ] = { 5 0 , 2 5 , 1 0 , 5 , 1 } ;
} int c o i n c h a n g e ( int n ) {
table [ 0 ] = 1;
//printMCM ( 0 ,N−1); f o r ( int i = 0 ; i < 5 ; i ++) {
void printMCM ( int i , int j ) { c = coins [ i ] ;
i f ( i == j ) p r i n t f ( ”A%d” , i ) ; f o r ( int j = c ; j <= n ; j ++)
else { t a b l e [ j ] += t a b l e [ j − c ] ;
putchar ( ’ ( ’ ) ; }
printMCM ( i , s [ i ] [ j ] ) ; return t a b l e [ n ] ;
putchar ( ’ ∗ ’ ) ; }
printMCM ( s [ i ] [ j ] + 1 , j ) ;
3.6 Coin Changing
putchar ( ’ ) ’ ) ;
}
int n [ 1 0 0 0 0 ] , i , N;
}
int c o i n s [ ] = { 5 0 , 2 5 , 1 0 , 5 , 1 } , k ;
3.4 Knapsack
s c a n f ( ”%d” , &N ) ;
int n [ WSIZE ] [ ISIZE ] = {{0}} f o r ( int i = 0 ; i <= N; i ++)

4
n [ i ] = INT MAX ; 3.8 Edit Distance
n [ 0 ] = 0;
Possible actions:
for ( int i = 0 ; i < 5 ; i ++) {
for ( k = 0 ; k <= N − c o i n s [ i ] ; k++) { 1. Delete a character
n [ k + coins [ i ] ] =
min ( n [ k ] + 1 , n [ k + c o i n s [ i ] ] ) ; 2. Insert a new character
}
} 3. Replace a character
p r i n t f ( ”%d\n” , n [N ] ) ;
int e d i t d i s t a n c e ( char ∗ s t r 1 , char ∗ s t r 2 ) {
int n [ SIZE ] [ SIZE ] ;
3.7 Biggest Sum int i , j , v a l u e ;

f o r ( i = 0 ; i <= s t r 1 l e n ; i ++) n [ i ] [ 0 ] = i ;
#define SIZE 20000 f o r ( j = 0 ; j <= s t r 2 l e n ; j ++) n [ 0 ] [ j ] = j ;
int n [ SIZE ] ;
f o r ( i = 1 ; i <= s t r 1 l e n ; i ++) {
int b i g g e s t s u m ( ) { f o r ( j = 1 ; j <= s t r 2 l e n ; j ++) {
int k , s , b ; v a l u e = ( s t r 1 [ i − 1 ] != s t r 2 [ j − 1 ] ) ;
int xl , xr , b e s t , prevx ;
n [ i ] [ j ] = min ( n [ i − 1 ] [ j − 1 ] + val ue ,
c i n >>k ; n[ i − 1][ j ] + 1,
for ( int i = 1 ; i <= k ; i ++) { n[ i ] [ j − 1] + 1);
xr = x l = 0 ; }
}
c i n >> s ; return n [ s t r 1 l e n ] [ s t r 2 l e n ] ;
fo r ( int j = 0 ; j < s − 1 ; j ++) }
c i n >> n [ j ] ; T( i , j ) = min ( C d + T( i −1, j ) ,
T( i , j −1) + C i ,
prevx = x l = xr = 0 ; T( i −1, j −1) + (A[ i ]==B [ j ] ? 0 : C r ) )
best = b = n [ 0 ] ;
fo r ( int j = 1 ; j < s − 1 ; j ++) {
3.9 Integer Partitions
i f (b < 0)
prevx = j ; P (n) represents the number of possible partitions of a natural
b = n [ j ] + max ( 0 , b ) ; number n. P (4) = 5, 4, 3 + 1, 2 + 2, 2 + 1 + 1, 1 + 1 + 1 + 1
i f (b > best | | P (0) = 1
( b == b e s t && P (n) = 0, n < 0
j − prevx > xr − x l ) ) { P (n) = p(1, n)
x l = prevx ; p(k, n) = p(k + 1, n) + p(k, n − k)
xr = j ; p(k, n) = 0 if k > n
best = b ; p(k, n) = 1 if k = n
}
}
3.10 Box Stacking
i f ( best > 0)
c o u t << ” B i g g e s t sum ” << i A set of boxes is given. Boxi = hi , wi , di .
<< i s between ”<< x l + 1 We can only stack box i on box j if wi < wj and di < dj .
<< and ” << xr + 2 To consider all the orientations of the boxes, re-
<< e n d l ; place each box with 3 boxes such that wi ≤ di and
} box1 [0] = hi , box2 [0] = wi , box3 [0] = di .
return 0 ; Then, sort the boxes by decreasing area(wi ∗ di ).
} H(j) =tallest stack of boxes with box j on top.

5
H(j) = maxi<j&wi >wj &di >dj (H(i)) + hj void r e c o n s t r u c t p a r t i t i o n (
Check H(j) for all values of j. const v e c t o r <int> &S , int n , int k ) {
i f ( k == 1 ) {
f o r ( int i = 1 ; i <= n ; i ++)
p r i n t f ( ”%d ” , &S [ i ] ) ;
3.11 Building Bridges p u t c h a r ( ’ \n ’ ) ;
Maximize number of non-crossing bridges. Ex: } else {
bridge1:2, 5, 1, n, · · · , 4, 3 r e c o n s t r u c t p a r t i t i o n ( S , D[ n ] [ k ] , k − 1 ) ;
bridge2:1, 2, 3, 4, · · · , n f o r ( int i = D[ n ] [ k ] + 1 ; i<= n ; i ++)
Let X(i) be the index of the corresponding city on northern p r i n t f ( ”%d ” , S [ i ] ) ;
bank. X(1) = 3, X(2) = 1, . . .. p u t c h a r ( ’ \n ’ ) ;
Find longest increasing subsequence of X(1), · · · , X(n). }
}

3.12 Partition Problem


Input: A given arrangement S of non-negative numbers
3.13 Balanced Partition
s1 , . . . , sn and an integer k.
Output: Partition S into k ranges, so as to minimize the
maximum sum over all the ranges. enum {DONT GET, GET} ;
char ∗∗ s o l , ∗∗P ;

int M[ 1 0 0 0 ] [ 1 0 0 ] , D[ 1 0 0 0 ] [ 1 0 0 ] ; // r e t u r n 1 i f t h e r e i s a s u b s e t
void p a r t i t i o n i ( v e c t o r <int> &v , int k ) { // o f v0 . . . v i w i t h sum j
int p [ 1 0 0 0 ] , n = v . s i z e ( ) ; // 0 o t h e r w i s e
v . i n s e r t (v . begin ( ) , 0 ) ; int c a l c P ( int i , int j , const v i &v ) {
p [ 0 ] = 0; i f ( i < 0 | | j < 0 ) return 0 ;
for ( int i = 1 ; i < v . s i z e ( ) ; i ++) i f (P [ i ] [ j ] != −1) return P [ i ] [ j ] ;
p[ i ] = p [ i − 1] + v [ i ] ;
i f ( j == 0 ) { // t r i v i a l c a s e
for ( int i = 1 ; i <= n ; i ++) s o l [ i ] [ j ] = DONT GET;
M[ i ] [ 1 ] = p [ i ] ; return P [ i ] [ j ] = 1 ;
for ( int i = 1 ; i <= k ; i ++) }
M[ 1 ] [ i ] = v [ 1 ] ; i f ( v [ i ] == j ) {
for ( int i = 2 ; i <= n ; i ++) { s o l [ i ] [ j ] = GET;
fo r ( int int j = 2 ; j <= k ; j ++) { return P [ i ] [ j ] = 1 ;
M[ i ] [ j ] = INT MAX << 1 − 1 ; }
int s = 0 ;
f o r ( int x = 1 ; x <= i − 1 ; x++) { int r e s 1 = c a l c P ( i − 1 , j , v ) ;
s = max(M[ x ] [ j − 1 ] , p [ i ] − p [ x ] ) ; int r e s 2 = c a l c P ( i − 1 , j − v [ i ] , v ) ;
i f (M[ i ] [ j ] > s ) { i f ( r e s 1 >= r e s 2 )
M[ i ] [ j ] = s ; P [ i ] [ j ] = r e s 1 , s o l [ i ] [ j ] = DONT GET;
D[ i ] [ j ] = x ; e l s e P [ i ] [ j ] = r e s 2 , s o l [ i ] [ j ] = GET;
} return P [ i ] [ j ] ;
} }
}
}
p r i n t f ( ”%d\n” , M[ n ] [ k ] ) ; // v i s t h e v e c t o r o f v a l u e s
} // k i s t h e maximum v a l u e i n v
// sum i s t h e sum o f a l l e l e m e n t s i n v
//n = number o f e l e m e n t s o f t h e i n i t i a l s e t void b a l a n c e d p a r t i t i o n ( v i &v ,

6
int k , int sum ) { 4 Graphs
P = new char ∗ [ v . s i z e ( ) ] ;
s o l = new char ∗ [ v . s i z e ( ) ] ; 4.1 Heap
for ( int i = 0 ; i < v . s i z e ( ) ; i ++) {
P [ i ] = new char [ k ∗ v . s i z e ( ) + 1 ] ; #define LEFT( i ) ( 2 ∗ ( i + 1 ) − 1 )
s o l [ i ] = new char [ k ∗ v . s i z e ( ) + 1 ] ; #define RIGHT( i ) ( 2 ∗ ( i + 1 ) )
fo r ( int j = 0 ; #define PARENT( i ) ( ( ( i ) + 1 ) / 2 − 1 )
j < k ∗ v . s i z e ( ) + 1 ; j ++)
P [ i ] [ j ] = −1, s o l [ i ] [ j ] = DONT GET; int ∗ min heap , ∗ h e a p p l a c e ;
} long int ∗ k e y s ;
for ( int i = 0 ; i < v . s i z e ( ) ; i ++) int h e a p s i z e =0;
fo r ( int j = 0 ;
j < v . s i z e ( ) ∗ k + 1 ; j ++) #define u p d a t e p l a c e ( i ) \
calcP ( i , j , v ) ; h e a p p l a c e [ min heap [ ( i ) ] ] = ( i )
// c a l c P ( v . s i z e ( ) − 1 , sum /2 , v ) ;
void i n i t h e a p ( int nelems ) {
int S = sum / 2 ; min heap = new int [ nelems ] ;
i f ( sum & 1 | | ! P [ v . s i z e ( ) − 1 ] [ S ] ) k e y s = new long int [ nelems ]
c o u t << ”ERROR” <<e n d l ; h e a p p l a c e = new int [ nelems ] ;
e l s e c o u t << ”SUCCESS” << e n d l ; h e a p s i z e = nelems ;
} f o r ( int i = 0 ; i < nelems ; i ++) {
min heap [ i ] = i ;
void free mem ( v i& v ) { heap place [ i ] = i ;
for ( int i = 0 ; i < v . s i z e ( ) ; i ++) { k e y s [ i ] = LONG MAX;
delete P [ i ] ; delete s o l [ i ] ; }
} }
delete [ ] P ;
delete [ ] s o l ; void h e a p m i n h e a p i f y ( int i ) {
} int s m a l l e s t , temp ;
int l = LEFT( i ) ;
// g e t s o l u t i o n ( v . s i z e ( ) − 1 , int r = RIGHT( i ) ;
// a c c u m u l a t e ( v . b e g i n ( ) , v . end ( ) , 0) / 2 ,
// v1 , v2 , v ) ; if ( l < heap size
void g e t s o l u t i o n ( int i , int j , && k e y s [ min heap [ l ] ]
v i &S1 , v i &S2 , v i &v ) { < k e y s [ min heap [ i ] ] )
i f ( j < 0 | | i < 0 ) return ; smallest = l ;
i f ( s o l [ i ] [ j ] == GET) { else smallest = i ;
S1 . push back ( v [ i ] ) ;
return g e t s o l u t i o n ( i − 1 , j − v [ i ] , i f ( r < h e a p s i z e &&
S1 , S2 , v ) ; k e y s [ min heap [ r ] ]
} else { < k e y s [ min heap [ s m a l l e s t ] ] )
S2 . push back ( v [ i ] ) ; smallest = r ;
return g e t s o l u t i o n ( i − 1 , j ,
S1 , S2 , v ) ; i f ( s m a l l e s t != i ) {
} temp = min heap [ i ] ;
} min heap [ i ] = min heap [ s m a l l e s t ] ;
min heap [ s m a l l e s t ] = temp ;
update place ( smallest ) ;
update place ( i ) ;
heap min heapify ( smallest ) ;

7
} int path ( int v ) {
} int w ;
f or ( ; a d j [ v ] . s i z e ( ) ; v = w) {
s . push ( v ) ;
int h e a p e x t r a c t m i n ( ) { l i s t <int > : : i t e r a t o r i t = a d j [ v ] . b e g i n ( ) ;
i f ( h e a p s i z e < 1) w = ∗it ;;
return −1; remove edge ( v ,w ) ;
int r e s = min heap [ 0 ] ; remove edge (w, v ) ;
h e a p s i z e −−; edges −−;
min heap [ 0 ] = min heap [ h e a p s i z e ] ; }
update place ( 0 ) ; return v ;
heap min heapify ( 0 ) ; }
return r e s ;
} //u − so u r c e , v−d e s t i n y
int e u l e r i a n p a t h ( int u , int v ) {
p r i n t f ( ”%d\n” , v ) ;
void h e a p d e c r e a s e k e y ( int elem , while ( path ( u ) == u && ! s . empty ( ) ) {
long int key ) { p r i n t f ( ”−%d” , u = s . top ( ) ) ;
int i = h e a p p l a c e [ elem ] ; s . pop ( ) ;
k e y s [ min heap [ i ] ] = key ;
}
return e d g e s == 0 ;
while ( i > 0 }
&& k e y s [ min heap [PARENT( i ) ] ] > 4.3 Breadth First Search
k e y s [ min heap [ i ] ] ) {
int temp = min heap [ i ] ;
min heap [ i ] = min heap [PARENT( i ) ] ; bool a d j [N ] [ N ] ;
min heap [PARENT( i ) ] = temp ; int c o l o u r [N] , d [N] , p [N ] ;
update place ( i ) ; void b f s ( ) {
u p d a t e p l a c e (PARENT( i ) ) ; queue<int> q ;
i = PARENT( i ) ; int s o u r c e = 0 ;
}
} f o r ( int i = 0 ; i < N; i ++) {
d [ i ] = INF ;
p [ i ] = −1;
4.2 Find an Eulerian Path c o l o u r [ i ] = WHITE;
}

s t a c k <int> s ; d [ source ] = 0;
v e c t o r <l i s t <int>> a d j ; c o l o u r [ s o u r c e ] = GRAY;
q . push ( s o u r c e ) ;
void remove edge ( int u , int v ) { while ( ! q . empty ( ) ) {
for ( l i s t <int > : : i t e r a t o r i t = a d j [ u ] . b e g i n ( ) ; int u = q . f r o n t ( ) ;
i t != a d j [ u ] . end ( ) ; i t ++) { q . pop ( ) ;
i f ( ∗ i t == v ) { f o r ( int v = 0 ; v < N; v++) {
i t = adj [ u ] . erase ( i t ) ; i f ( c o l o u r [ v ] == WHITE
return ; && a d j [ u ] [ v ] ) {
} c o l o u r [ v ] = GRAY;
} d [ v ] = d [ u]+1;
} p[v] = u;

8
q . push ( v ) ; case GRAY:
} c o l o r [ u]=BLACK;
} d f s . pop ( ) ;
c o l o u r [ u ] = BLACK; // p u t node i n f r o n t o f a l i s t
} // i f t o p s o r t
} // SCC1 : c l o s e t i m e . p u s h b a c k ( u ) ;
break ;
4.4 DFS/TopSort case BLACK:
O(V + E) d f s . pop ( ) ;
Recursive: break ;
}
void d f s ( int u ) { }
c o l o u r [ u ] = GRAY; }
for ( int v = 0 ; v < N; v++) {
i f ( c o l o u r [ v ] == WHITE && a d j [ u ] [ v ] ) { Maximum Spanning Tree:
p[v] = u; Negate all the edge weights and determine the minimum span-
dfs (v ) ; ning tree.
} Minimum Product Spanning Tree:
} Replace all the edge weights with their logarithm
c o l o u r [ u ] = BLACK; Strongly Connected Components:
// p u t node i n f r o n t o f a l i s t i f t o p s o r t 1. Run DFS: Save closing times of all vertexes.
}
2. Compute adj t.
Iterative:
3. Run DFS: Reverse order of closing times. In adj t.
typedef enum {WHITE, GRAY, BLACK} c o l o r t ;
v e c t o r <c o l o r t > c o l o r ; 4. Each resulting tree is a SCC.
// SCC: v e c t o r <i n t > c l o s e t i m e ;
4.5 Prim’s Algorithm
s t a c k <int> d f s ;
c o l o r = v e c t o r <c o l o r t >(N, WHITE) ; 4.5.1 Naive version
for ( int i = 0 ; i < N; i ++) {
i f ( c o l o r [ i ] != WHITE) double Prim ( int s t a r t , int n v e r t ) {
continue ; bool i n [N ] ;
d f s . push ( i ) ; double d i s t [N ] ;
// SCC2 : f o r ( i n t i = N − 1 ; i >= 0 ; i −−) { int p [N] , v ;
// SCC2 : i f ( c o l o r [ c l o s e t i m e [ i ] ] != WHITE)
// continue ; f o r ( int i = 0 ; i < n v e r t ; i ++) {
// SCC2 : d f s . push ( c l o s e t i m e [ i ] ) ; in [ i ] = false ;
while ( ! d f s . empty ( ) ) { d i s t [ i ] = INT MAX ;
int u = d f s . top ( ) ; p [ i ] = −1;
switch ( c o l o r [ u ] ) { }
case WHITE:
c o l o r [ u ] = GRAY; dist [ start ] = 0;
for ( v in adj [ u ] ) { v = start ;
// SCC2 : f o r ( v i n a d j t [ u ] ) { while ( ! i n [ v ] ) {
i f ( c o l o r [ v ] == WHITE) { i n [ v ] = true ;
d f s . push ( v ) ; f o r ( int i = 0 ; i < n v e r t ; i ++) {
} i f ( a d j [ v ] [ i ] && ! i n [ i ] ) {
} i f ( d i s t [ i ] > adj [ v ] [ i ] ) {
break ; d i s t [ i ] = adj [ v ] [ i ] ;

9
p[ i ] = v; s . i n s e r t ( node ) ;
} }
} }
} }

double d = FLT MAX; ull res = 0;


fo r ( int i = 0 ; i < n v e r t ; i ++) { f o r ( int i = 0 ; i < n v e r t ; i ++)
i f ( ! i n [ i ] && d > d i s t [ i ] ) { r e s += d i s t [ i ] ;
v = i; return r e s ;
d = dist [ i ] ; }
}
} 4.6 Dijkstra
} 4.6.1 Naive version
double r e s = 0 ;
for ( int i = 0 ; i < n v e r t ; i ++) int d i j k s t r a ( int s o u r c e , int d e s t ,
r e s += d i s t [ i ] ; int nvert , int d [ ] , int p [ ] ) {
return r e s ; bool i n [N ] ;
} int u ;
4.5.2 Set version
f o r ( int i = 0 ; i < n v e r t ; i ++) {
in [ i ] = false ;
s t d : : v e c t o r <s t d : : p a i r <int , int> > graph [ SIZE ] ; d [ i ] = INF ;
p [ i ] = −1;
struct cmp fn { }
bool operator ( ) ( const int&a , d [ source ] = 0;
const int &b ) const { u = source ;
return d i s t [ a ] < d i s t [ b ] | | while ( ! i n [ u ] ) {
( d i s t [ a ] == d i s t [ b ] && a < b ) ; i n [ u ] = true ;
} f o r ( int v = 0 ; v < n v e r t ; v++) {
}; i f ( adj [ u ] [ v ]
int Prim ( int s t a r t , int n v e r t ) { && d [ v ] > d [ u ] + a d j [ u ] [ v ] ) {
s e t <int , cmp fn> s ; p[v] = u;
dist [ start ] = 0; d [ v ] = d [ u ] + adj [ u ] [ v ] ;
s . insert ( start ); }
}
while ( s . s i z e ( ) ) {
int v = ∗ ( s . b e g i n ( ) ) ; int d i s t = INT MAX ;
s . erase ( s . begin ( ) ) ; f o r ( int i = 0 ; i < n v e r t ; i ++) {
i f ( ! i n [ i ] && d [ i ] < d i s t ) {
i n [ v ] = true ; u = i;
fo r ( unsigned int i = 0 ; dist = d[ i ] ;
i < graph [ v ] . s i z e ( ) ; i ++) { }
int node = graph [ v ] [ i ] . f i r s t ; }
int l e n g t h = graph [ v ] [ i ] . s e c o n d ; }
i f ( ! i n [ node ] ) { return d [ d e s t ] ;
i f ( d i s t [ node ] > l e n g t h ) { }
i f ( s . f i n d ( node ) != s . end ( ) )
s . e r a s e ( s . f i n d ( node ) ) ; 4.6.2 Set version
d i s t [ node ] = l e n g t h ;
} #define VPI s t d : : v e c t o r <s t d : : p a i r <int , int>>

10
}
int d i j k s t r a ( const VPI graph [ SIZE ] ,
int S , int T) { v v i d i j k s t r a ( int s o u r c e , int d e s t , int K) {
dist [ S ] = 0; v e c t o r <int> count ( SIZE ) , d ( 1 0 0 0 0 ) ,
p ( 1 0 0 0 0 ) , h ( 1 0 0 0 0 ) , X;
s e t <Node> s ; vvi res ;
s . i n s e r t ( Node ( S ) ) ;
f o r ( int i = 0 ; i < N; i ++)
int u = S ; p [ i ] = −1;
while ( s . s i z e ( ) ) { int elm = 1 ;
Node n = ∗ ( s . b e g i n ( ) ) ; h [ elm ] = s o u r c e ;
s . erase ( s . begin ( ) ) ; d [ elm ] = 0 ;
u = n.x; X. push back ( elm ) ;
s e e n [ u ] = true ;
while ( count [ d e s t ] < K && !X. empty ( ) ) {
unsigned int i ; int i n d = 0 ;
fo r ( i = 0 ; i < graph [ u ] . s i z e ( ) ; ++i ) { f o r ( unsigned int i = 1 ;
int node = graph [ u ] [ i ] . f i r s t ; i < X. s i z e ( ) ; i ++) {
int l a t = graph [ u ] [ i ] . s e c o n d ; i f ( d [X[ i ] ] < d [X[ i n d ] ] )
i f ( ! s e e n [ node ] ind = i ;
&& d i s t [ node ] > d i s t [ u ] + l a t ) { }
i f ( s . f i n d ( Node ( node ) ) int k = X[ i n d ] ;
!= s . end ( ) ) { X. e r a s e (X. b e g i n ( ) + i n d ) ;
s . e r a s e ( s . f i n d ( Node ( node ) ) ) ; int i = h [ k ] ;
}
d i s t [ node ] = d i s t [ u ] + l a t ; count [ i ]++;
s . i n s e r t ( Node ( node ) ) ; i f ( i == d e s t ) {
} v e c t o r <int> v ;
} path ( k , p , h , v ) ;
} r e s . push back ( v ) ;
}
return d i s t [ T ] ;
} i f ( count [ i ] <= K) {
f o r ( int j = 0 ;
4.7 Kth Shortest Paths O(Km) j < SIZE ; j ++) {
i f ( adj [ i ] [ j ] ) {
/∗ elm++;
∗ u − s o u r c e node d [ elm ] = d [ k ] + a d j [ i ] [ j ] ;
∗ p − predecessor vector p [ elm ] = k ;
∗ h − vector of transformation h [ elm ] = j ;
∗ v − result vector X. push back ( elm ) ;
∗/ }
#d e f i n e v v i v e c t o r <v e c t o r <int> > }
void path ( int u , const v e c t o r <int> &p , }
const v e c t o r <int> &h , }
v e c t o r <int> &v ) { return r e s ;
i f ( u != −1) { }
path ( p [ u ] , p , h , v ) ;
v . push back ( h [ u ] ) ; 4.8 Floyd-Warshall O(n3 )
}

11
void f l o y d ( int a d j [NVERT ] [ NVERT] ) { p u t s ( ” N e g a t i v e edge w e i g h t
for ( int k = 1 ; k <= NVERT; k++) { cycles detected ! ” ) ;
fo r ( int i = 1 ; i <= NVERT; i ++) { free ( distance );
f o r ( int j = 1 ; j <= NVERT; j ++) { return ;
int t h r o u g h k = a d j [ i ] [ k ] }
+ adj [ k ] [ j ] ; }
i f ( through k < adj [ i ] [ j ] )
adj [ i ] [ j ] = through k ; f o r ( int i = 0 ; i < nodecount ; i ++) {
} p r i n t f ( ”The s h o r t e s t d i s t a n c e between
} nodes %d and %d i s %d\n” ,
} source , i , distance [ i ] ) ;
} }
delete [ ] d i s t a n c e ;
4.9 Bellman-Ford }

typedef struct {
int s o u r c e ;
int d e s t ;
int w e i g h t ;
} Edge ;
4.10 Detecting Bridges
void BellmanFord ( Edge e d g e s [ ] , int edgecount ,
int nodecount , int s o u r c e ) {
int ∗ d i s t a n c e = new int [ nodecount ] ;
for ( int i =0; i < nodecount ; i ++)
d i s t a n c e [ i ] = INT MAX ;
int d f s ( int u , int p ) {
// s o u r c e node d i s t a n c e i s s e t t o z e r o colour [ u ] = 1;
distance [ source ] = 0; dfsNum [ u ] = num++;
int l e a s t A n c e s t o r = num ;
for ( int i = 0 ; i < nodecount ; i ++) { f o r ( int v = 0 ; v < N; v++) {
fo r ( int j = 0 ; j < e d g e c o u n t ; j ++) { i f (M[ u ] [ v ] && v!=p ) {
i f ( distance [ edges [ j ] . source ] i f ( c o l o u r [ v ] == 0 ) {
!= INT MAX) { int r e c = d f s ( v , u ) ;
int n e w d i s t a n c e = i f ( r e c > dfsNum [ u ] )
distance [ edges [ j ] . source ] + c o u t << ” B r i d g e : ”
edges [ j ] . weight ; << u <<” ” << v
<< e n d l ;
i f ( new distance < leastAncestor =
distance [ edges [ j ] . dest ] ) min ( l e a s t A n c e s t o r , r e c ) ;
distance [ edges [ j ] . dest ] = }
new distance ; else {
} l e a s t A n c e s t o r = min ( l e a s t A n c e s t o r ,
} dfsNum [ v ] ) ;
} }
}
for ( int i = 0 ; i < e d g e c o u n t ; i ++) { }
i f ( distance [ edges [ i ] . dest ] > colour [ u ] = 2;
distance [ edges [ i ] . source ] + return l e a s t A n c e s t o r ;
edges [ i ] . weight ) { }

12
4.11 Finding a Loop in a Linked List O(n) do c r e a t e s e t ( i ) ;

f u n c t i o n b o o l e a n hasLoop ( Node s t a r t N o d e ) { f o r each edge ( u , v )


Node slowNode , fastNode1 , f a s t N o d e 2 ; i f ( f i n d s e t ( u ) != f i n d s e t ( v ) )
slowNode = f a s t N o d e 1 = f a s t N o d e 2 = s t a r t N o d e ;
merge sets (u , v ) ;
while ( slowNode && f a s t N o d e 1 = f a s t N o d e 2 . next ( )
&& f a s t N o d e 2 = f a s t N o d e 1 . next ( ) ) {
}
i f ( slowNode == f a s t N o d e 1 | |
slowNode == f a s t N o d e 2 ) bool same conponents ( int u , int v ) {
return true ; i f ( f i n d s e t ( u ) == f i n d s e t ( v ) )
slowNode = slowNode . next ( ) ; return true ;
} e l s e return f a l s e ;
return f a l s e ; }
}
4.14 Edmonds Karp
4.12 Tree diameter
struct edge {
Pick a root and start a DFS from it which returns both the
int d e s t ;
diameter of the subtree and its maximum height. The diam-
int max weight ;
eter is the maximum of (left diameter, right diameter, left
int f l o w ;
height + right height).
edge ∗ r e s i d u a l ;
}
4.13 Union Find
int nnodes ;
int Rank [ SIZE ] ;
int P [ SIZE ] ; typedef map<int , edge∗> node ;
typedef node ∗∗ graph ;
void c r e a t e s e t ( int x ) { graph g r a f o ;
P[ x ] = x ;
Rank [ x ] = 0 ; void c r e a t e e d g e ( int s o u r c e ,
} int d e s t , int w e i g h t ) {
i f ( ( ∗ g r a f o [ s o u r c e ] ) . f i n d ( d e s t ) ==
void m e r g e s e t s ( int x , int y ) { ( ∗ g r a f o [ s o u r c e ] ) . end ( ) ) {
int px = f i n d s e t ( x ) ; edge ∗ e = new edge ;
int py = f i n d s e t ( y ) ; edge ∗ r e s = new edge ;
i f ( Rank [ px ] > Rank [ py ] ) e−>d e s t = d e s t ;
P [ py ] = px ; r e s −>d e s t=s o u r c e ;
e l s e P [ px ] = py ; e−>max weight=w e i g h t ;
r e s −>max weight=w e i g h t ;
i f ( Rank [ px ] == Rank [ py ] ) e−>f l o w =0;
Rank [ py]++; r e s −>f l o w=w e i g h t ;
} e−>r e s i d u a l=r e s ;
r e s −>r e s i d u a l=e ;
int f i n d s e t ( int x ) { (∗ grafo [ source ] ) [ dest ] = e ;
i f ( x != P [ px ] ) (∗ grafo [ dest ] ) [ source ] = r e s ;
P [ x ] = f i n d s e t (P [ x ] ) ; return ;
return P [ x ] ; }
}
edge ∗ e = ( ∗ g r a f o [ s o u r c e ] ) [ d e s t ] ;
void c o n n e c t e d c o m p o n e n t s ( ) { edge ∗ r e s = e−>r e s i d u a l ;
for each v e r t e x i e−>max weight += w e i g h t ;

13
r e s −>max weight += w e i g h t ; memset ( v i s i t e d , 0 , s i z e o f ( v i s i t e d ) ) ;
r e s −>f l o w += w e i g h t ;
} // C r e a t e a queue
// enqueue s o u r c e v e r t e x and
int u p d a t e p a t h ( int f l o w s o u r c e , // mark s o u r c e v e r t e x as v i s i t e d
int f l o w d e s t ) { s t d : : queue <int> q ;
int f l o w = INT MAX ; q . push ( s ) ;
int noded = f l o w d e s t ; v i s i t e d [ s ] = true ;
while ( noded != f l o w s o u r c e ) { p a r e n t [ s ] = −1;
int s o u r c e=p [ noded ] ;
edge ∗ e =(∗ g r a f o [ s o u r c e ] ) [ noded ] ; // Standard BFS Loop
i f ( flow >e−>max weight−e−>f l o w ) { while ( ! q . empty ( ) ) {
f l o w=e−>max weight−e−>f l o w ; int u = q . f r o n t ( ) ;
} q . pop ( ) ;
noded=s o u r c e ;
} f o r ( int v = 0 ; v < V; v++) {
i f ( v i s i t e d [ v ] == f a l s e
noded=f l o w d e s t ; && rGraph [ u ] [ v ] > 0 ) {
while ( noded != f l o w s o u r c e ) { q . push ( v ) ;
int s o u r c e = p [ noded ] ; parent [ v ] = u ;
edge ∗ e = ( ∗ g r a f o [ s o u r c e ] ) [ noded ] ; v i s i t e d [ v ] = true ;
e−>f l o w+=f l o w ; }
e−>r e s i d u a l −>flow−=f l o w ; }
noded=s o u r c e ; }
}
return f l o w ; // I f we r e a c h e d s i n k i n BFS s t a r t i n g from
} // s o u r c e , t h e n r e t u r n t r u e , e l s e f a l s e
return ( v i s i t e d [ t ] == true ) ;
int edmonds karp ( int s o u r c e , int d e s t ) { }
int r e s = 0 ;
while ( 1 ) { 4.16 Widest path problem
bfs ( source ) ;
In an undirected graph, a widest path may be found as the
i f ( c o l o u r [ d e s t ] == WHITE) {
path between the two vertices in the maximum spanning tree
return r e s ;
of the graph
}
r e s += u p d a t e p a t h ( s o u r c e , d e s t ) ;
}
return r e s ; 5 Geometrical Algorithms
}
5.1 Circle
4.15 Ford Fulkerson
Formula is given by
#define V 110
int graph [V ] [ V ] ; x2 + y 2 = r 2

bool b f s ( int rGraph [V ] [ V] , int s , 5.2 Triangle’s medians


int t , int p a r e n t [ ] ) {
// C r e a t e a v i s i t e d a r r a y and Any triangle’s area T can be expressed in terms of its medians
// mark a l l v e r t i c e s as not v i s i t e d ma , mb , mc as follows. Denoting their semi-sum (ma + mb +
bool v i s i t e d [V ] ; mc)/2 as s, we have

14
Given two different points (x1 , y1 ) and (x2 , y2 ) the
4p values of A,B, and C for Ax + By + C = 0 are given by
A= s(s − ma )(s − mb )(s − mc )
3
The sides of the triangle are given, from the medians: A = y2 − y1
B = x1 − x2
2
q C = A ∗ x1 + B ∗ y1
a= −m2a + 2m2b + 2m2c
3
2 5.7 Intersection of segments
q
b= −m2b + 2m2a + 2m2c
3
2 double d e t = A1∗B2 − A2∗B1
q
c= −m2c + 2m2b + 2m2a
3 i f ( d e t == 0 ) {
// L i n e s a r e p a r a l l e l
} else {
double x = −(A1∗C2 − A2∗C1) / d e t
5.3 Heron’s formula double y = −(B1∗C2 − B2∗C1) / d e t
a+b+c }
s=
2 5.8 Position of point in relation to line
Area is given by
// I n p u t : t h r e e p o i n t s P0 , P1 , and P2
p // Return : >0 f o r P2 l e f t o f t h e l i n e t h r o u g h P0 and P1
A= s(s − a)(s − b)(s − c) // = 0 f o r P2 on t h e l i n e
// < 0 f o r P2 r i g h t o f t h e l i n e
int i s L e f t ( Poi nt P0 , Poi nt P1 , Point P2 ) {
5.4 Dot Product return ( ( P1 . x − P0 . x ) ∗ ( P2 . y − P0 . y )
− ( P2 . x − P0 . x ) ∗ ( P1 . y − P0 . y ) ) ;
}
int dot ( int [ ] A, int [ ] B, int [ ] C) {
int AB[ 2 ] , BC [ 2 ] ;
5.9 Distance between point and line/seg-
AB[ 0 ] = B[0] −A [ 0 ] ;
AB[ 1 ] = B[1] −A [ 1 ] ; ment
BC [ 0 ] = C[0] −B [ 0 ] ; If the line is in the form Ax + By + C = 0:
BC [ 1 ] = C[1] −B [ 1 ] ;
int dot = AB [ 0 ] ∗ BC [ 0 ] + AB [ 1 ] ∗ BC [ 1 ] ; |Ax0 + By0 + C|
d= √
return dot ; A2 + B 2
}
//Compute t h e d i s t . from AB t o C
5.5 Cross Product // i f i s S e g m e n t=s t r u e , AB i s a s e g . , not a l i n e .
double l i n e P o i n t D i s t ( int [ ] A, int [ ] B,
int c r o s s ( int [ ] A, int [ ] B, int [ ] C) { int [ ] C, b o o l e a n i s S e g m e n t ) {
int AB[ 2 ] , AC [ 2 ] ; double d i s t = c r o s s (A, B, C) / d i s t a n c e (A, B ) ;
AB[ 0 ] = B[0] −A [ 0 ] ; i f ( isSegment ) {
AB[ 1 ] = B[1] −A [ 1 ] ; int dot1 = dot (A, B, C ) ;
AC[ 0 ] = C[0] −A [ 0 ] ; i f ( dot1 > 0 )
AC[ 1 ] = C[1] −A [ 1 ] ; return d i s t a n c e (B, C ) ;
int c r o s s = AB [ 0 ] ∗ AC[ 1 ] − AB [ 1 ] ∗ AC [ 0 ] ; int dot2 = dot (B, A, C ) ;
return c r o s s ; i f ( dot2 > 0 )
} return d i s t a n c e (A, C ) ;
}
5.6 Point on segment return abs ( d i s t ) ;
}
A point is on a segment if its distance to the segment is 0.

15
5.10 Polygon Area f o r ( u i n t 6 4 t i = 0 ; i < q l . s i z e ( ) ; i ++) {
point p = ql [ i ] ;
int a r e a = 0 ;
/∗ i n t N = l e n g t h o f ( p ) ; ∗/ while ( j < qr . s i z e ( )
&& qr [ j ] . y < p . y − d e l t a )
for ( int i = 1 ; i + 1 < N; i ++) { j ++;
int x1 = p [ i ] [ 0 ] − p [ 0 ] [ 0 ] ;
int y1 = p [ i ] [ 1 ] − p [ 0 ] [ 1 ] ; uint64 t k = j ;
int x2 = p [ i + 1 ] [ 0 ] − p [ 0 ] [ 0 ] ; while ( k < qr . s i z e ( )
int y2 = p [ i + 1 ] [ 1 ] − p [ 0 ] [ 1 ] ; && qr [ k ] . y <= p . y + d e l t a ) {
int c r o s s = x1 ∗ y2 − x2 ∗ y1 ; dm = min (dm, d i s t ( p , qr [ k ] ) ) ;
a r e a += c r o s s ; k++;
} }
return f a b s ( a r e a / 2 . 0 ) ; }
return dm;
5.11 Convex Hull }

#include <v e c t o r > vp s e l e c t c a n d i d a t e s ( vp &p , int l , int r ,


v e c t o r <p o i n t > ConvexHull ( v e c t o r <p o i n t > P) { double d e l t a , double midx ) {
int n = P . s i z e ( ) , k = 0 ; vp n ;
v e c t o r <p o i n t > H( 2 ∗ n ) ; f o r ( int i = l ; i <= r ; i ++) {
i f ( abs ( p [ i ] . x − midx ) <= d e l t a )
// S o r t p o i n t s l e x i c o g r a p h i c a l l y n . push back ( p [ i ] ) ;
s o r t (P . b e g i n ( ) , P . end ( ) ) ; }
return n ;
// B u i l d l o w e r h u l l }
for ( int i = 0 ; i < n ; i ++) {
while ( k >= 2 double c l o s e s t p a i r ( vp &p , int l , int r ) {
&& c r o s s (H[ k −2] , H[ k −1] , P [ i ] ) <= 0 ) i f ( r − l + 1 < 2 ) return INT MAX ;
k−−; int mid = ( l + r ) / 2 ;
H[ k++] = P [ i ] ; double midx = p [ mid ] . x ;
} double d l = c l o s e s t p a i r ( p , l , mid ) ;
double dr = c l o s e s t p a i r ( p , mid + 1 , r ) ;
// B u i l d upper h u l l double d e l t a = min ( dl , dr ) ;
for ( int i = n−2, t = k+1; i >= 0 ; i −−) {
while ( k >= t vp ql , qr ;
&& c r o s s (H[ k −2] , H[ k −1] , P [ i ] ) <= 0 ) ql = s elect can didates (p , l ,
k−−; mid , d e l t a , midx ) ;
H[ k++] = P [ i ] ; qr = s e l e c t c a n d i d a t e s ( p , mid + 1 ,
} r , d e l t a , midx ) ;

H. r e s i z e ( k ) ; double dm = d e l t a m ( ql , qr , d e l t a ) ;
return H;
} vp r e s ;
merge ( p . b e g i n ( ) + l , p . b e g i n ( ) + mid + 1 ,
5.12 Closest pair of points p . b e g i n ( ) + mid + 1 , p . b e g i n ( ) + r + 1 ,
b a c k i n s e r t e r ( r e s ) , cmp ) ;
double d e l t a m ( vp &ql , vp &qr , double d e l t a ) { copy ( r e s . b e g i n ( ) , r e s . end ( ) , p . b e g i n ( ) + l ) ;
uint64 t j = 0; return min (dm, min ( dr , dm ) ) ;
double dm = d e l t a ; }

16
5.13 Test if point is inside a polygon + pow ( y r e s − by , 2 ) ) ;
}
int wn PnPoly ( P o in t P , P oi nt ∗ V, int n ) {
int wn = 0 ; // t h e w i n d i n g number c o u n t e r return 0 ;
}
// l o o p t h r o u g h a l l e d g e s o f t h e p o l y g o n

for ( int i = 0 ; i < n ; i ++) {
i f (V[ i ] . y <= P . y ) { 6 Numerical
i f (V[ i + 1 ] . y > P . y )
i f ( i s L e f t (V[ i ] , 6.1 Check if float is an integer
V[ i + 1 ] , P) > 0 )
++wn ; #define EQ( a , b ) ( f a b s ( ( a ) − ( b ) ) < EPS)
} else { #define IS INT ( a ) ( EQ( ( a ) , c e i l ( a ) ) | | \
i f (V[ i + 1 ] . y <= P . y ) EQ( ( a ) , f l o o r ( a ) ) )
i f ( i s L e f t (V[ i ] ,
V[ i +1] , P) < 0 ) 6.1.1 Big Mod
−−wn ;
(B P )%M
}
} typedef long long int l l i ;
return wn ;
} long int bigmod ( long long int B,
long long int P , long long int M) {
5.14 Circle from 3 points i f (P == 0 )
return 1 ;
int main ( ) { e l s e i f (P & 1 ) {
double ax , ay , bx , by , cx , cy , x r e s , y r e s ; l l i tmp =
double xmid , ymid , A1 , B1 , C1 , A2 , C2 , B2 , d i s t ; bigmod (B , ( P − 1 ) >> 1 , M) % M;
tmp = ( tmp ∗ tmp ∗ B) % M;
while ( s c a n f ( ”%l f %l f %l f %l f %l f %l f ” , return tmp ;
&ax ,&ay ,&bx ,&by ,& cx ,& cy )==6) { } else {
A1 = by − ay ; l l i tmp = bigmod (B, P >> 1 , M) % M;
B1 = ax − bx ; return ( tmp ∗ tmp ) % M;
xmid = min ( ax , bx ) + (max( ax , bx ) }
− min ( ax , bx ) ) / 2 . 0 ; }
ymid = min ( ay , by ) + (max( ay , by )
− min ( ay , by ) ) / 2 . 0 ;
C1 = −B1 ∗ xmid + A1 ∗ ymid ; 6.2 Triangle area
B2 = bx − cx ; 1
A= ∗ a ∗ b ∗ sin(C)
A2 = cy − by ; 2
xmid = min ( bx , cx ) + (max( bx , cx )
− min ( bx , cx ) ) / 2 . 0 ; 6.3 Heron’s formula
ymid = min ( by , cy ) + (max( by , cy )
− min ( by , cy ) ) / 2 . 0 ; Let s = 21 (a + b + c) then
C2 = −B2 ∗ xmid + A2 ∗ ymid ; p
A= s(s − a)(s − b)(s − c)
// i n t e r s e c t i o n o f segments
i n t e r s e c t i o n (A1 , B1 , C1 , A2 , 6.4 Choose
B2 , C2 , &x r e s , &y r e s ) ;
n

d i s t = s q r t ( pow ( x r e s − bx , 2 ) k

17
long long memo [ SIZE ] [ SIZE ] ; // i n i t i a l i z e d t o −1 int i , j ;
long long binom ( int n , int k ) { f o r ( i = 0 ; num ; i ++) {
i f (memo [ n ] [ k ] != −1) return memo [ n ] [ k ] ; tmp [ i ] =
i f ( n < k ) return 0 ; ” 0123456789ABCDEFGHIJKLM” [ num % b a s e ] ;
i f ( n == k ) return 1 ; num /= b a s e ;
i f ( k == 0 ) return 1 ; }
return memo [ n ] [ k ] = binom ( n − 1 , k ) tmp [ i ] = 0 ;
+ binom ( n − 1 , k − 1 ) ; f o r ( i −−, j = 0 ; i >= 0 ; i −−, j ++)
} r e s [ j ] = tmp [ i ] ;
res [ j ] = 0;
}
6.5 Modulo:
6.8 Horner’s Rule
int mod( int a , int n ) { n
X
return ( a%n + n)%n ; P (x) = ak xk = a0 + x(a1 + x(a2 + · · · + (an−1 + x1n )))
} k=0

6.6 LCM / GCD double Horner ( double c o e f [ ] , int d e g r e e , int x ) {


double r e s = 0 ;
gcd(a, b) ∗ lcm(a, b) = a ∗ b
f o r ( int i = d e g r e e ; i >= 0 ; i −−)
int gcd ( int a , int b ) { res = coef [ i ] + x ∗ res ;
i f ( ! b) return r e s ;
return a ; }
e l s e return gcd ( b , a % b ) ;
}
6.9 Matrix Multiplication
struct t r i p l e {
int gcd , x , y ; void M a t r i x M u l t i p l y ( int A[N ] [ P ] ,
int t r i p l e ( int g = 0 , int a = 0 , int b = 0 ) : int B [ P ] [M] , int N) {
gcd ( g ) , x ( a ) , y ( b ) {} int C [N ] [M] , i , j , k ;
}; f o r ( i = 0 ; i < N; i ++){
f o r ( j = 0 ; j < P ; j ++){
t r i p l e ExtendedEuclid ( int a , int b ) { C[ i ] [ j ] = 0 ;
i f ( ! b) f o r ( k = 0 ; k < P ; k++)
return t r i p l e ( a , 1 , 0 ) ; C [ i ] [ j ] += A[ i ] [ k ] ∗ B [ k ] [ j ] ;
}
t r i p l e t = ExtendedEuclid ( b , a % b ) ; }
return t r i p l e ( t . gcd , t . y , }
t . x − (a / b) ∗ t . y ) ;
} 6.10 Long Arithmetic
Take care of leading zeroes.
int LCM( int a , int b ) { Addition:
return a ∗ b / gcd ( a , b ) ;
} // make s u r e num1 and num2 a r e
// f i l l e d w i t h ’ \ 0 ’ a f t e r d i g i t s
void add ( char ∗num1 , char ∗num2 , char ∗ r e s ) {
6.7 Base conversion int i , c a r r y =0;
r e v e r s e (num1 , num1 + s t r l e n (num1 ) ) ;
void b a s e ( char ∗ r e s , int num , int b a s e ) { r e v e r s e (num2 , num2 + s t r l e n (num2 ) ) ;
char tmp [ 1 0 0 ] ;

18
for ( i = 0 ; num1 [ i ] | | num2 [ i ] ; i ++){ // i t s p r e c e d e n c e i s <= than a
r e s [ i ] = num1 [ i ] + num2 [ i ] //
− ’0 ’ + carry ; // b i s r i g h t a s s o c i a t i v e and
i f ( ! num1 [ i ] | | ! num2 [ i ] ) // i t s p r e c i s < than a
r e s [ i ] += ’ 0 ’ ; bool b e p r e c ( char a , char b ) {
i f ( r e s [ i ] > ’ 9 ’ ){ int p [ 3 0 0 ] ;
carry = 1; p [ ’+ ’ ] = p [ ’− ’ ] = 1 ;
r e s [ i ] −= 1 0 ; p[ ’∗ ’ ] = p[ ’/ ’ ] = 2;
} else carry = 0; return p [ a ] >= p [ b ] ;
} }
i f ( carry ) res [ i ] = ’1 ’ ;
reverse ( res , res + s t r l e n ( res ) ) ; s t r i n g s h u n t i n g y a r d ( s t r i n g exp ) {
} int i = 0 ;
string res ;
Multiplication
s t a c k <char> s ; // o p e r a t o r s (1 cha r ! )
void mul ( char ∗num1 , char ∗num2 , char ∗ s t r ) {
int i , j , r e s [ 2 ∗ SIZE ] = { 0 } , c a r r y = 0 ; while ( i < exp . s i z e ( ) ) {
// i f i t ’ s a f u n c t i o n t o k e n
r e v e r s e (num1 , num1 + s t r l e n (num1 ) ) ; // push i t onto t h e s t a c k
r e v e r s e (num2 , num2 + s t r l e n (num2 ) ) ;
for ( i = 0 ; num1 [ i ] ; i ++) // I f i t i s a func arg
fo r ( j = 0 ; num2 [ j ] ; j ++) // s e p a r a t o r ( e . g . , a comma ) :
r e s [ i + j ] += (num1 [ i ] − ’ 0 ’ ) // U n t i l t h e topmost
∗ (num2 [ j ] − ’ 0 ’ ) ; // elem o f t h e s t a c k i s ’ ( ’
for ( i = 2 ∗ SIZE − 1 ; // pop t h e elem from t h e s t a c k and
i >= 0 && ! r e s [ i ] ; i −−); // append i t t o r e s .
// I f no ’ ( ’ −> e r r o r
i f ( i < 0) { // do not pop ’ ( ’
strcpy ( str , ”0” ) ;
return ; i f ( i s d i g i t ( exp [ i ] ) | | exp [ i ] == ’ x ’ ) {
} // number . add i s a l p h a ( ) f o r v a r s
for ( j = 0 ; i >= 0 ; i −−, j ++){ f o r ( ; i < exp . s i z e ( )
str [ j ] = res [ i ] + carry ; && ( i s d i g i t ( exp [ i ] )
carry = str [ j ] / 10; | | exp [ i ] == ’ x ’ ) ;
s t r [ j ] %= 1 0 ; i ++) {
s t r [ j ] += ’ 0 ’ ; r e s . push back ( exp [ i ] ) ;
} }
i f ( carry ) r e s . push back ( ’ ’ ) ;
str [ j ] = carry + ’0 ’ ; i −−; // t h e r e ’ s a i++ down t h e r e
} } e l s e i f ( exp [ i ] == ’ ( ’ ) {
s . push ( ’ ( ’ ) ;
} e l s e i f ( exp [ i ] == ’ ) ’ ) {
6.11 Infix para Postfix while ( ! s . empty ( )
&& s . top ( ) != ’ ( ’ ) {
r e s += s . top ( ) + s t r i n g ( ” ” ) ;
#define o p e r ( a ) ( ( a ) == ’+ ’ | | ( a ) == ’− ’ \\ s . pop ( ) ;
| | ( a ) == ’ ∗ ’ | | ( a ) == ’ / ’ ) }
i f ( s . top ( ) != ’ ( ’ ) ; // e r r o r
// t r u e i f e i t h e r : !! e l s e s . pop ( ) ;
// b i s l e f t a s s o c i a t i v e and } e l s e i f ( o p e r ( exp [ i ] ) ) { // o p e r a t o r

19
while ( ! s . empty ( ) return s . top ( ) ;
&& o p e r ( s . top ( ) ) }
&& b e p r e c ( s . top ( ) , exp [ i ] ) ) {
r e s += ( s . top ( ) + s t r i n g ( ” ” ) ) ; 6.13 Postfix to Infix
s . pop ( ) ;
} /∗
s . push ( exp [ i ] ) ; ∗ Pass a s t a c k w i t h t h e e x p r e s s i o n
} ∗ to rpn2infix .
i ++; ∗ Ex : ( bottom ) 3 4 5 ∗ + ( t o p )
} ∗/
while ( ! s . empty ( ) ) { s t r i n g r p n 2 i n f i x ( s t a c k <s t r i n g > &s ) {
i f ( s . top ( ) == ’ ( ’ s t r i n g x = s . top ( ) ;
| | s . top ( ) == ’ ) ’ ) s . pop ( ) ;
c o u t << ” E r r o r ” << e n d l ; i f ( i s d i g i t ( x [ 0 ] ) ) return x ;
r e s += ( s . top ( ) + s t r i n g ( ” ” ) ) ; e l s e return s t r i n g ( ” ( ” ) +
s . pop ( ) ; rpn2infix ( s ) + x +
} rpn2infix ( s ) + string (”)” );
i f ( ∗ ( r e s . end ( ) − 1 ) == ’ ’ ) }
r e s . e r a s e ( r e s . end ( ) − 1 ) ;
return r e s ; 6.14 Matrix Multiplication
} n
X
Cij = aik .bkj
6.12 Calculate Postfix expression k=1

// exp i s i n p o s t f i x void matrix mul ( int A[N ] [ P ] , int B [ P ] [M] ) {


double c a l c ( s t r i n g exp ) { int C [N ] [M] , i , j , k ;
s t a c k <double> s ; f o r ( i = 0 ; i <N; i ++) {
i s t r i n g s t r e a m i s s ( exp ) ; f o r ( j = 0 ; j <P ; j ++) {
s t r i n g op ; C[ i ] [ j ]=0;
f o r ( k=0;k<P ; k++)
while ( i s s >> op ) { C [ i ] [ j ]+=A[ i ] [ k ] ∗B [ k ] [ j ] ;
// ATTENTION TO THIS }
i f ( op . s i z e ( ) == 1 && o p e r ( op [ 0 ] ) ) { }
i f ( s . s i z e ( ) < 2) }
e x i t ( −1); // e r r o r
double a = s . top ( ) ; s . pop ( ) ;
double b = s . top ( ) ; s . pop ( ) ;
6.15 Catalan Numbers
switch ( op [ 0 ] ) {
case ’+ ’ : s . push ( b + a ) ; break ; (2n)!
Cn =
case ’− ’ : s . push ( b − a ) ; break ; (n + 1)!n!
case ’ ∗ ’ : s . push ( b ∗ a ) ; break ;
case ’ / ’ : s . push ( b / a ) ; break ; • Cn counts the number of expressions containing n pairs
} of parentheses which are correctly matched
} else {
i s t r i n g s t r e a m i s s 2 ( op ) ; • Cn is the number of different ways a convex polygon with
double tmp ; n+2 sides can be cut into triangles by connecting vertices
i s s 2 >> tmp ; with straight lines.
s . push ( tmp ) ;
}
6.16 Fibonnaci
}

20
long f i b ( long n ) { }
long matrix [ 2 ] [ 2 ] = { { 1 , 1 } , { 1 , 0 } } ;
long r e s [ 2 ] [ 2 ] = { { 1 , 1 } , { 1 , 0 } } ; return l ;
while ( n ) { }
i f (n & 1) {
matrix mul ( matrix , r e s , r e s ) ; 7.3 Binary Search - Upper bound
}
matrix mul ( matrix , matrix , matrix ) ; int upper bound ( int l , int r , u l l q ) {
n /= 2 ; while ( l < r ) {
} int mid = ( l+r ) / 2 ;
return r e s [ 1 ] [ 1 ] ;
} i f ( v [ mid ] < q ) {
l = mid + 1 ;
7 Sorting / Search } e l s e i f ( v [ mid ] > q ) {
r = mid − 1 ;
7.1 Counting Sort } else {
l = mid+1;
}
int count [ SIZE ] = { 0 } ;
}
int output [ SIZE ] = { 0 } ;
void l i n e a r s o r t ( int v [ SIZE ] , int N) {
return l ;
int max = 0 ;
}
for ( int i = 0 ; i < N; ++i ) {
i f ( v [ i ] > max)
max = v [ i ] ;
count [ v [ i ] ] + + ;
}

for ( int i = 1 ; i <= max ; ++i ) {


count [ i ] += count [ i − 1 ] ;
}

for ( int i = 0 ; i < N; ++i ) {


output [ count [ v [ i ] ] − 1 ] = v [ i ] ;
count [ v [ i ]] − −;
}
}

7.2 Binary Search - Lower bound

int lower bound ( int l , int r , u l l q ) {


while ( l < r ) {
u l l mid = ( l+r ) / 2 ;

i f ( v [ mid ] < q ) {
l = mid + 1 ;
} e l s e i f ( v [ mid ] > q ) {
r = mid − 1 ;
} else {
r = mid ;
}

21

You might also like