Trang chủ Tin Học Lớp 8 Nhờ các cao nhân giải giúp =( C++ nha Một...

Nhờ các cao nhân giải giúp =( C++ nha Một chiếc cặp có thể chứa rất nhiều viên bi với các loại màu khác nhau. Cho mảng arr chứa số lương bi của các loại bi đó,

Câu hỏi :

Nhờ các cao nhân giải giúp =( C++ nha Một chiếc cặp có thể chứa rất nhiều viên bi với các loại màu khác nhau. Cho mảng arr chứa số lương bi của các loại bi đó, đếm số bi cần lấy ra tối thiểu để chắc chắn có được n loại. Nếu không thể tìm ra đáp án, trả về -1. Ví dụ: Với arr = [1,2,3], n = 3 thì bags_and_marbles(arr,n) = 6 Giải thích: Trong trường hợp này ta phải lấy tất cả 6 viên bi mới chắc chắn lấy được 3 loại bi. Với arr = [9,2,3,5,2,7], n = 4 thì bags_and_marbles(arr,n) = 22 Giải thích: Trong trường hợp này ta phải lấy tất cả ít nhất 22 viên bi mới chắc chắn lấy được 4 loại bi. Nếu lấy ít hơn, chẳng hạn 21 viên, ta có thể lấy 9 viên bi ở vị trí đầu tiên trong mảng, 7 viên bi ở vị trí cuối trong mảng, và 5 viên bi ở vị trí thứ tư (Các vị trí đếm từ 1) thì chỉ thu được 3 loại.

Lời giải 1 :

Đây nha em

#include <bits/stdc++.h>
#define debug(x) cerr << #x << " = " << x << endl;
#define task ""
using namespace std;
int n, k; // k là số loại bi mà đề bài yêu cầu, n là số loại bi có
int a[10001], ans=0;
int main()
{
    //freopen(task".inp", "r", stdin);
    //freopen(task".out", "w", stdout);
    ios_base::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    cin >> n >> k;
    for (int i=1; i<=n; i++)
    {
        cin >> a[i];
    }
    sort (a+1, a+1+n); //xếp lại số bi từ nhỏ đến lớn
    for (int i=n; i>=n-k+2; i--)
    {
        ans += a[i];
    }
    cout << ans+1;
    #ifdef dungctb
    cerr << "Time collapse : " << fixed << setprecision(3) << 1.000*clock()/CLOCKS_PER_SEC;
    #endif // dungctb

    return 0;
}

Thảo luận

-- vậy thì bài này chưa làm đc đâu :(
-- int bagsAndMarbles(int[] arr, int n) { } ở đây là code cho java anh chỉ e cái nào cũng được ạ
-- Nhập vào cái đó thì như này #include <bits/stdc++.h> #define debug(x) cerr << #x << " = " << x << endl; #define task "" using namespace std; int n, k; // k là số loại bi mà đề bài yêu cầu int a[10001], ans=0; int bagsAndMarbles(int arr[], int n) { ... xem thêm
-- điền vào { } mà anh
-- ừ. điền vào { } là cái sort (arr+1, arr+1+n); //xếp lại số bi từ nhỏ đến lớn for (int i=n; i>=n-k+2; i--) { ans += arr[i]; } cout << ans+1; đó
-- https://codelearn.io/fightstask/index?id=1544018&taskid=1532052 anh vào đây xem thử ạ =(
-- Ủa đang thi sao lại hỏi thế này?
-- e nghĩ mãi ko ra ạ =(((((((((((((((((((((((((((((

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