Trang chủ Tin Học Lớp 8 Câu 1: (4,0 điểm) Mẹ nhờ Bo ra chợ lấy...

Câu 1: (4,0 điểm) Mẹ nhờ Bo ra chợ lấy hàng hóa để chuẩn bị bán hàng vào dịp Tết sắp đến. Do chưa biết hàng hóa được đóng gói như thế nào nên Bo mang theo

Câu hỏi :

các cao nhân giúp mình với

image

Lời giải 1 :

Ý tưởng

Nếu bạn không hiểu, bạn có thể hỏi

Ta gọi f[i] là số cách để tạo ra i kg chỉ bằng 2 túi đã cho

Dễ thấy, f[0] = 1 (vì ta chẳng cần túi nào để đựng cả), f[i] = 0 nếu i < 0 (vì ta không thể tạo ra khối lượng âm bằng các túi có khối lượng dương)

Ta lại có: f[i] = f[i-a] + f[i-b]. Tại sao? Do ta luôn có thể tạo ra i kg từ i-a kg bởi ta chỉ cần cho thêm 1 túi a kg vào. Ta có được f[i-a] cách do ta chỉ có 1 cách duy nhất để tạo ra i từ i-a Tương tự với i-b.

Vậy ta có thể mang được một khối lượng m lớn nhất về khi nào? Khi f[m] > 0. Mà m <= n và m phải lớn nhất (do không thể đựng m kg vào thùng chứa n kg được) => Ta sẽ duyệt từng f[i] với i từ n -> 0, nếu f[i] > 0 ta lập tức in ra kết quả và thoát khỏi vòng lặp. Cách duyệt như vậy sẽ luôn đảm bảo sẽ in ra kết quả do f[0] = 1

Để ý thêm 1 điều nữa: Chúng ta không cần quan tâm đến số cách để tạo ra i kg, vì vậy ta có thể biến mảng f[i] thành mảng boolean, với mỗi giá trị f[i] là khả năng tạo ra i kg.

Code

#include <bits/stdc++.h>
using namespace std;

const int maxn = 1005;

int n,a,b;
bool dp[maxn];

int main(){
    ios_base::sync_with_stdio(0);cin.tie(0);cout.tie(0);

    cin >> n >> a >> b;
    dp[0] = 1;
    for(int i=1;i<=n;i++){
        if(i >= a) dp[i] = dp[i-a];
        if(i >= b) dp[i] = (dp[i] || dp[i-b]);
    }
    while(n >= 0){
        if(dp[n]){
            cout << n; return 0;
        }
        n--;
    }
    return 0;
}

Thảo luận

-- 10/10 luôn
-- Mà dc cái là nó lạc đề :))
-- Vừa nghĩ ra cách làm Python 5 dòng :))
-- https://hoidap247.com/cau-hoi/4867193 ->https://hoidap247.com/cau-hoi/4867193 cứuuuu
-- Vừa nghĩ ra cách làm Python 5 dòng :)) -> nhưng mà bài này làm = pas :))
-- lạc đề gì vậy bạn mình làm c++ để tham khảo thôi (mình cũng chẳng để ý là nó là ngôn ngữ nào)
-- nếu bạn hoanganhnguyen có ý tưởng gì tốt hơn thì có thể trả lời giúp bạn. Nhiều bài giải cũng tốt mà
-- Nhưng mà tus muốn làm pascal

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 :))

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

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

Copyright © 2021 HOCTAPSGK