Trang chủ Tin Học Lớp 11 Trích đề thi chọn học sinh giỏi tin THPT cấp...

Trích đề thi chọn học sinh giỏi tin THPT cấp tỉnh lớp 12 tỉnh Hưng Yên năm 2018 1 Đã xóa 2. Viết bằng Pascal 3. Giới hạn TG :không quá 1s

Câu hỏi :

Trích đề thi chọn học sinh giỏi tin THPT cấp tỉnh lớp 12 tỉnh Hưng Yên năm 2018 1 Đã xóa 2. Viết bằng Pascal 3. Giới hạn TG :không quá 1s

image

Lời giải 1 :

// Yo fenwick tree :v (tại a không nghĩ ra cách tốt hơn v:)

uses crt;
type 
    int = longint;
const
    maxn = trunc(1e5);
var
    bit: array[0..maxn + 10] of longint;
    i, n, m, k, size: longint;

procedure update(idx: int; val: int);
begin
    while idx <= size do begin
        inc(bit[idx], val);
        inc(idx, idx and (-idx));
    end;
end;

function get(idx: int): int;
var res: int;
begin
    res:=0;
    while idx > 0 do begin
        inc(res, bit[idx]);
        dec(idx, idx and (-idx));
    end;
    exit(res);
end;

function find(ss, sum: int): int;
var 
    s1, s2: int;
    l, r, mid: int;
begin
    s1:=get(ss - 1);
    s2:=n - i;
    
    if s2 - s1 + sum >= m then begin
        l:=ss; r:=n;
        while l <= r do begin
            mid:=(l + r) shr 1;
            if (get(mid) - s1 + sum) <= m - 1 then l:=mid + 1 else r:=mid - 1;
        end;
        exit(l);
        
    end else begin
        sum:=sum + (s2 - s1);
        sum:=sum + (m - sum - 1) div s2 * s2;
        while sum >= m do dec(sum, m);
        exit(find(1, sum));
    end;
    
end;

begin
    clrscr;
    readln(n, m);
    size:=n + 5;
    
    for i:=1 to n do update(i, 1); 
    
    for i:=0 to n - 1 do begin
        k:=find(k, 0);
        update(k, -1);
        write(k, ' '); 
    end;
end.

Thảo luận

-- Khiếp cái bài
-- hàm get(idx) để lấy tổng từ 1 đến (idx) update(idx, val) để tăng phần tử (idx) lên (val) v:
-- Dạ vâng anh ạ

Bạn có biết?

Tin học, tiếng Anh: informatics, tiếng Pháp: informatique, là một ngành khoa học chuyên nghiên cứu quá trình tự động hóa việc tổ chức, lưu trữ, xử lý và truyền dẫn thông tin của một hệ thống máy tính cụ thể hoặc trừu tượng (ảo). Với cách hiểu hiện nay, tin học bao hàm tất cả các nghiên cứu và kỹ thuật có liên quan đến việc mô phỏng, biến đổi và tái tạo thông tin.

Nguồn : Wikipedia - Bách khoa toàn thư

Tâm sự 11

Lớp 11 - Năm thứ hai ở cấp trung học phổ thông, gần đến năm cuối cấp nên học tập là nhiệm vụ quan trọng nhất. Nghe nhiều đến định hướng sau này rồi học đại học. Ôi nhiều lúc thật là sợ, hoang mang nhưng các em hãy tự tin và tìm dần điều mà mình muốn là trong tương lai nhé!

Nguồn : ADMIN :))

Liên hệ hợp tác hoặc quảng cáo: gmail

Điều khoản dịch vụ

Copyright © 2021 HOCTAPSGK