Trang chủ Tin Học Lớp 8 Trong khuôn viên trường có N cây xanh được đánh...

Trong khuôn viên trường có N cây xanh được đánh số từ 1 đến N, cây thứ i (1 ≤ i ≤ N) có chiều cao Hi và giá trị thẩm mĩ là Ci (1 ≤ Hi, Ci ≤ 10^9). Nhà trường g

Câu hỏi :

Trong khuôn viên trường có N cây xanh được đánh số từ 1 đến N, cây thứ i (1 ≤ i ≤ N) có chiều cao Hi và giá trị thẩm mĩ là Ci (1 ≤ Hi, Ci ≤ 10^9). Nhà trường giao cho mỗi lớp chọn ra 3 cây bất kì để chăm sóc. Lớp 9A muốn chọn 3 cây theo thứ tự i,j, k sao cho có tổng giá trị thẩm mĩ lớn nhất đồng thời thỏa mãn điều kiện 1 ≤ i

Lời giải 1 :

Ở đây mình sẽ dùng mảng a kiểu bản ghi gồm 2 trường.

+ h:longint → chiều cao của cây

+c:longint → độ thẩm mĩ của cây

Trong đề có 2 điều kiện

+ ĐK 1: 1 ≤ i ≤ j ≤ k ≤ N (Do chỉ in tổng giá trị thẩm mỹ lớn nhất nên không cần quan tâm. Không như điều kiện 2 vì 3 phần tử ở vị trí khác nhau thì i,j,k chắc chắn khác nhau)

+ ĐK 2: Hi < Hj < Hk(Điều kiện này chỉ cần quan tâm là 3 cái giá trị khác nhau thôi ko cần quan tâm cái nào nhỏ,lớn hơn vì chỉ xuất ra tổng thôi.)

Sau đó mình chỉ cần sắp xếp độ thẩm mĩ từ bé đến lớn. Xoá các phần tử có chiều cao lớn nhưng bằng nhau sau đó tính tổng 3 phần tử đầu tiên(lớn nhất và đạt yêu cầu).

Code

Program tinh;
Type
    caicay = record
        h:longint;
        c:longint;
end;
Var a:array[1..3000] of caicay;
i,n,j,s:longint;
t:caicay;
fi,fo:text;
BEGIN
assign(fi,'cau2.inp');
assign(fo,'cau2.out');
reset(fi);
Readln(fi,n);
For i:= 1 to n do Read(fi,a[i].h);
Readln(fi);
For i:= 1 to n do Read(fi,a[i].c);
close(fi);
For i:= 1 to n - 1 do
    For j:=i+1 to n do
    If a[i].c < a[j].c then begin t:=a[i]; a[i]:=a[j]; a[j]:= t end;
For i:=2 to 3 do While a[i].h = a[i-1].h do begin a[i]:=a[i+1]; n:= n - 1;end;

s:=a[1].c+a[2].c+a[3].c;
rewrite(fo);
Writeln(fo,s);
close(fo);
END.

Thảo luận

-- Bạn kiểm tra lại giúp mk nhe
-- https://hoidap247.com/cau-hoi/4038204 giúp nha
-- bạn có thể code bài này trên C++ dc ko
-- Cũng được nhưng mà mình hổng biết input bằng file trong c++ thế nào nha Nếu được thì mình thử code
-- giống như trên đề bài

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ự 8

Lớp 8 - Năm thứ ba ở cấp trung học cơ sở, học tập bắt đầu nặng dần, sang năm lại là năm cuối cấp áp lực lớn dần nhưng các em vẫn phải chú ý sức khỏe nhé!

Nguồn : ADMIN :))

Copyright © 2021 HOCTAP247