02/10/2018, 13:59

MINCUT spoj – VOI 2015 Day 2 – Cắt hình

Lời giải cho đề thi học sinh giỏi quốc qua môn tin học năm học 2014 – 2015, VOI 2015. MINCUT spoj – VOI 2015 Day 2 – Cắt hình Nguồn đề bài : http://vn.spoj.com/problems/MINCUT/ 1. Đề bài MINCUT spoj Cho A là lưới ô vuông gồm m dòng và n cột. Các dòng của lưới được đánh số ...

Lời giải cho đề thi học sinh giỏi quốc qua môn tin học năm học 2014 – 2015, VOI 2015. MINCUT spoj – VOI 2015 Day 2 – Cắt hình

Nguồn đề bài: http://vn.spoj.com/problems/MINCUT/

1. Đề bài MINCUT spoj

Cho A là lưới ô vuông gồm m dòng và n cột. Các dòng của lưới được đánh số từ 1 đến m, từ trên xuống dưới. Các cột của lưới được đánh số từ 1 đến n, từ trái sang phải. Ô nằm trên giao của dòng i và cột j của lưới, được gọi là ô (ij), chứa số nguyên không âm ai,jcó giá trị không vượt quá 106.

Các lưới ô vuông như vậy luôn là đối tượng cho nhiều nghiên cứu thú vị. Vừa qua, trong giờ học ôn luyện cho kỳ thi học sinh giỏi Tin học, Hùng được cô giáo giao cho giải quyết bài toán trả lời truy vấn sau đây đối với bảng đã cho:

Cho một hình chữ nhật con có ô trái trên là ô (x,y) và ô phải dưới là ô (u,v), cần đưa ra chênh lệch nhỏ nhất trong số các chênh lệch giữa hai tổng các số trong hai hình chữ nhật thu được bằng việc cắt ngang hoặc cắt dọc hình chữ nhật đã cho dọc theo đường kẻ của lưới. Giả thiết (x,y) và (u,v) là hai ô khác nhau trên lưới.

Bạn hãy giúp Hùng giải quyết bài toán đặt ra.

Yêu cầu: Cho lưới A k bộ xq, yq , uqvq (q = 1, 2, …, k) tương ứng với k truy vấn, hãy đưa ra các câu trả lời cho k truy vấn.

Dữ liệu vào

  • Dòng đầu tiên chứa ba số nguyên m, n, k (k m×n);
  • m dòng tiếp theo, dòng thứ i chứa n số nguyên không âm ai1, ai2, …, ain;
  • Dòng thứ q trong số k dòng tiếp theo chứa 4 số nguyên xq, yq, uq, vq (q = 1, 2, …, k).

Dữ liệu ra

  • Ghi ra file văn bản MINCUT.OUT gồm k dòng, mỗi dòng chứa một số là câu trả lời cho một truy vấn theo thứ tự xuất hiện trong file dữ liệu vào.

Ràng buộc

  • Có 30% số test ứng với 30% số điểm của bài có m, n ≤ 10.
  • Có 30% số test khác ứng với 30% số điểm của bài có  m, n ≤ 100.
  • Có 40% số test  ứng với 40% số điểm còn lại của bài có m, n ≤ 1000.

Ví dụ

Input

3 3 2
1 1 1
1 1 1
1 1 1
1 1 3 3
1 1 3 2

Output

3

0

2. Hướng dẫn MINCUT spoj

– Xây dựng mảng tổng A[i,j] là tổng của hình chữ nhật từ ô 1;1 đến ô i;j. giống như bài BONUS trên vn spoj.

BONUS spoj – VOI 2011 Phần thưởng

vừa nhập vừa xử lí có thể viết như sau:

for i:=1 to m do

for j:=1 to n do

begin

read(f,a[i,j]);

A[i,j]:=A[i,j]+A[i-1,j]+a[i,j-1]-A[i-1,j-1];

end;

– Sau đó chặt nhị phân để tìm độ chênh lệch nhỏ nhất. ý tưởng là vậy, cách chặt nhị phân các bạn có thể tham khảo code mẫu.

Độ phức tạp thuật toán: O(n^2 log2 N).

3. code tham khảo MINCUT spoj

a. Code Pascal

b. Code C++