Top posts
-
10 thuật toán đang chế ngự thế giới chúng ta [part 1]
Thuật toán là gì? Về mặt lí thuyết, thuật toán là một thủ tục tính toán, nhận đầu vào là một tập các giá trị được gọi là input và tạo ra một tập các giá trị được gọi là output. Vì vậy thuật toán là một chuỗi các bước biến đổi input thành output. -Nguồn:...
-
[Dịch] Chiến thuật ACM-ICPC [3x1=4]
Điều căn bản: Luyện tập, Luyện tập, Luyện tập! Để chiến thuật được thực hiện hiệu quả, bạn không cần phải là thiên tài bởi vì việc luyện tập có thể đưa bạn đi đủ xa. Trong triết lí của chúng tôi, có 3 đặc điểm mấu chốt để tạo nên 1 team xuất sắc: Kiến...
-
[LCA] Jakarta 2010 - Lightning Energy Report
Cho 1 cây n đỉnh (2N50, 000) và Q thao tác (Q<=50000). Mỗi truy vấn có dạng (u v c) : cộng vào mỗi nút trên đường đi từ u đến v 1 giá trị c (<=100). Ban đầu mỗi nút có giá trị = 0. Yêu cầu: tìm giá trị mỗi nút sau khi thực hiện Q thao tác Sample Input...
-
Chiến thuật ACM [3x1=4]
Điều căn bản: Luyện tập, Luyện tập, Luyện tập! Để chiến thuật được thực hiện hiệu quả, bạn không cần phải là thiên tài bởi vì việc luyện tập có thể đưa bạn đi đủ xa. Trong triết lí của chúng tôi, có 3 đặc điểm mấu chốt để tạo nên 1 team xuất sắc: Kiến...
-
[DP level 2] UVA 1172 The Bridges of ...
King Beer muốn xây 1 vài cây cầu kết nối các ngân hàng ở 2 bên bờ sông. Cầu chỉ nối được 2 ngân hàng sử dụng cùng hệ điều hành. Và 2 cây cầu ko thể cắt nhau Giá trị kinh tế của 1 cây cầu = tổng gia trị giao thương của 2...
-
[MST] Jakarta 2008- Anti Brute Force Lock
What's done is done. But in order to slow down future robbers' attack, Panda Security Agency (PSA) has devised a new safer lock with multiple keys. Instead of using only one key combination as the key, the lock now can have up to N keys which has to be...
-
[Dp level 3] UVA 1240 ICPC Team Strategy
Chiến thuật của 1 team ACM 3 người như sau: + trong 20ph đầu học sẽ đọc đề và mỗi người sẽ xác định đk thời gian để accept mỗi bài của mình + trong 280ph còn lại họ sẽ chia nhau làm + chỉ có 1 máy tính nên tại 1 thời điểm...
-
[Dp Optimization 1] 2010 TopCoder High School Round 1 - Division I TheSequencesLevelThree
Cho dãy A gồm n phần từ nguyên đôi một phân biệt (n<=50, A[i]<=1e9) và giá trị k. Đếm số cách sắp xếp dãy A thành dãy số dạng "mountain" có chênh lệch giữa 2 phân tử liên tiếp <=k. Một dãy số đgl "mountain" nếu tồn tại 0
-
[Meet in the middle] SUBSUMS - spoj
Cho n số (1<=n<=34) S1 đến Sn ( |Si|<=20m). Đếm số tập con S (gồm cả tập rỗng) có tổng thuộc khoảng A,B ( |A|,|B|<=500m) Input: 3 -1 2 1 -2 3 Output: 5The following 5 subsets have a sum between -1 and 2: 0 = 0 (the empty subset) 1 = 1 1 + (-2) = -1 -2...
-
Spoj VPalin POI 2006
Cho n xâu palindrome, đếm số lượng cặp xâu sao cho khi ghép chúng lại ta được 1 xâu palindrome. Tổng độ dài của n xâu <= 2.000.000 Input: 3 1 a 2 bb 2 aa Output: 5 The 5 palindromes are: aa aaa aaa bbb aaaa Algorithms: Nhận xét: 1 xâu palindrome <=> period...
-
[Dp bitmask] Baby-spoj
Một đứa bé cố gắng giải quyết bài toán n quân hậu: đặt n quân hậu lên bàn cờ n*n sao cho ko có 2 quân nào ăn được nhau. Bé đa thành công trong việc đặt n quân hậu lên để ko có 2 quân nào cùng hàng và cột nhưng vẫn còn khả năng 2 quân nằm trên cùng 1 đường...
-
[Nim game] CF 15C. Industrial Nim
Có n mỏ đá. Mỏ đá i có mi xe đá: xe 1 chứa xi viên đá xe 2 chưa xi+1 viên đá ... xe mi chứa xi+mi-1 viên đá Ở mỗi lượt chơi, người chơi sẽ được chọn 1 xe đá bất kì và lấy ra 1 lượng đá bất kì từ nó. Người lấy đk những viên đá cuối cùng sẽ chiến thắng....
-
[Dp level 2] UVA 10898 Combo Deal
1 cửa hàng bán các sản phẩm theo 2 kiểu: đơn lẻ hoặc combo. Ví dụ Hamburger $3.49 Fries $0.99 Pop $1.09 Ice Cream $2.19 Value Meal (1 Hamburger, 1 Fries, 1 Pop) $4.79 Lovers-Only (2 Hamburgers, 2 Fries, 2 Pops, 1 Ice Cream) $9.99 Cho danh...
-
[Dp level 2] UVA 11832 Account Book
Cho dãy n (<=40) số và giá trị F. Ta có thể điền +, - vào trước mỗi số để tạo ra tổng đại số = F theo nhiều cách: Vd 6+7-7+7-1=12 6-7+7-7-1=12 7+7-7+7-1=12 Tuy nhiên , để tạo ra tổng F, ta có thể biết chắc chắn trước số 6...
-
[Dp Optimization 2] Member Single Round Match 468 R1 - Div I RoadOrFlightHard
Đức vua đang ở thành phố 0, Hoàng hậu đang ở thành phố n. Có các con đường bộ và bay nối giữa mọi cặp thành phố (i,i+1). Thời gian để đi bộ từ i => i+1 được biểu diễn = roadTime[i] roadTime[0] = roadFirst mod roadMod; for i = 1 to N-1 roadTime[i] = (roadTime[i-1]*roadProd...
-
[Nim game] Jakarta 2010 - Playing With Stones
Cho n đống sỏi, đống i chưa a[i] viên. Ở mỗi lượt đi, mỗi người phải lấy ra ít nhất 1 viên từ 1 đống, nhưng số sỏi lấy ra phải <= 1/2 số viên sỏi trong đống đó. Người chơi nào ko thể lấy sỏi ra sẽ thua. Xác định xem người đi trước có thể thắng ko? (n<=100,...
-
[Wp] Lấy dữ liệu json từ API google map
Tạo DataContract cho json: { "routes" : [ { "legs" : [ { "distance" : { "text" : "1,1 km", "value" : 1126 }, "steps" : [{ "duration" : "2 phút" }] }] }] } DataContract: [DataContract] class DirectionDataContract { [DataMember(Name = "routes")] public...
-
[MST] Kaohsiung 2006 The Bug Sensor Problem
Đề khó hiểu vc. Tóm tắt Cho n cột wifi trên mặt phẳng và m thiết bị thu phát. Hai cột wifi có thể trao đổi thông tin nếu khoảng cách giữa chúng <= D. M thiết bị thu phát sẽ được lắp vào m cột wifi (m<=n) , thiết bị này sẽ truyền thông tin về căn cứ. Tìm...
-
[MST] UVA 10600 - ACM Contest and Blackout
Tìm cây khung nhỏ nhất và cây khung nhỏ thứ 2 Algorithms: Tìm cây khung nhỏ nhất rồi đánh dấu các cạnh thuộc cây khung nhỏ nhất Với mỗi cạnh đã đánh dấu tìm cây khung nhỏ nhất ko chứa cạnh đó: - Union tất cả các cạnh đk đánh dấu ngoại trừ cạnh đang xét...
-
CF 432D Prefixes and Suffixes
Cho xâu S, nhiệm vụ là với mỗi xâu con vừa là prefix vừa là suffix in ra số lần nó xuất hiện trong S. |S|<=10^5 Algorithm: Để làm được bài này cần hiểu sâu sắc ý nghĩa của prefix function trong phần khởi tạo của KMP F[0] = F[1] = 0; for(int i = 2;i<=n;i++){...
-
CF126B Password
Cho xâu S |S|<=1000.000. Tìm substring P dài nhất của S sao cho P vừa là prefix vừa là suffix vừa xuất hiện ở giữa S (không trùng prefix, suffix) Sample test(s) input fixprefixsuffix output fix input abcdabc output Just a legend Dùng Z-algorithm xấy dựng...
-
CF79C Beaver
Cho n xâu b1,b2,..,bn được xem là boring và xâu S. Tìm substring dài nhất của S ko chứa n xâu boring như là substring (n<=10, |S|<=10^5) Sample test(s) input Go_straight_along_this_street 5 str long tree biginteger ellipse output 12 4 input IhaveNoIdea...
-
[Jakarta 2013] Pasti Pas!
UMột xâu có thể được viết thành dạng palindrom nếu ta thay 1 hoặc 1 số substring của nó = 1 biểu tượng khá. Ví dụ Let S = ‘ABCADDABCA’. There are several derivations of S, e.g.: • Let α = ‘ABCA’, β = ‘DD’, then S′ = ‘αβα’ which has a length of 3. • Let...
-
[Manacher] Spoj Paliny
Tìm substring dài nhất là palindrome của 1 xâu S |S|<=50000 Manacher: Đầu tiên biến đổi xâu S bằng cách thêm xen giữa các kí tự của S kí tự #, thêm vào đầu S kí tự ^, cuối S kí tự $ Ví dụ S=abba => S=^#a#b#b#a#$ Như vậy mọi Palin Substring (PS) bây giờ...
-
[Manacher] Codechef TACHEMIS
http://www.codechef.com/problems/TACHEMIS Algorithm: Áp dụng manacher cho n compressed string Do nếu các các compressed string ghép lại đk thành 1 PS thì độ dài của PS đó chắc chắn lẻ nên ta ko cần bước thêm các "#" như Manacher nguyên bản int C = 1,...