Program C++ untuk mengetahui bilangan mata minimum yang diperlukan untuk mencapai skor G

WBOY
Lepaskan: 2023-09-06 21:25:06
ke hadapan
846 orang telah melayarinya

Program C++ untuk mengetahui bilangan mata minimum yang diperlukan untuk mencapai skor G

Andaikan kita mempunyai dua tatasusunan p dan c, setiap tatasusunan mempunyai elemen D, dan terdapat satu lagi nombor G. Pertimbangkan bahawa dalam pertandingan pengaturcaraan, setiap soalan diberi markah berdasarkan kesukarannya. Markah soalan p[i] ialah 100i. Masalah p[1] + ... + p[D] ini adalah semua masalah dalam pertandingan. Pengguna di laman web pengaturcaraan mempunyai jumlah_skor berangka. Jumlah_skor pengguna ialah jumlah dua elemen berikut.

  • Skor asas: Jumlah markah semua masalah yang diselesaikan

  • Ganjaran: Apabila pengguna menyelesaikan semua masalah dengan skor 100i, sebagai tambahan kepada skor asas, ganjaran yang sempurna c[ i] akan diperolehi .

Amal baru dalam pertandingan dan masih belum menyelesaikan sebarang masalah. Matlamatnya adalah untuk mendapatkan gred keseluruhan G atau lebih. Kita perlu mengetahui berapa banyak masalah yang perlu dia selesaikan sekurang-kurangnya untuk mencapai matlamat ini.

Jadi jika input adalah G = 500; P = [3, 5]; C = [500, 800] maka output akan menjadi 3

Langkah

Untuk menyelesaikan masalah ini kita akan mengikuti langkah berikut:

D := size of p
mi := 10000
for initialize i := 0, when i < 1 << D, update (increase i by 1), do:
sum := 0
count := 0
at := 0
an array to store 10 bits b, initialize from bit value of i
for initialize j := 0, when j < D, update (increase j by 1), do:
   if jth bit in b is 1, then:
      count := p[j]
      sum := sum + ((j + 1) * 100 * p[j] + c[j]
   Otherwise
      at := j
if sum < G, then:
   d := (G - sum + (at + 1) * 100 - 1) / ((at + 1) * 100)
   if d <= p[at], then:
      sum := sum + (at + 1)
      count := count + d
if sum >= G, then:
   mi := minimum of mi and count
return mi
Salin selepas log masuk

Contoh

Mari kita lihat pelaksanaan di bawah untuk pemahaman yang lebih baik −

#include <bits/stdc++.h>
using namespace std;
int solve(int G, vector<int> p, vector<int> c){
   int D = p.size();
   int mi = 10000;
   for (int i = 0; i < 1 << D; i++){
      int sum = 0;
      int count = 0;
      int at = 0;
      bitset<10> b(i);
      for (int j = 0; j < D; j++){
         if (b.test(j)){
            count += p.at(j);
            sum += (j + 1) * 100 * p.at(j) + c.at(j);
         } else {
            at = j;
         }
      }
      if (sum < G){
         int d = (G - sum + (at + 1) * 100 - 1) / ((at + 1) * 100);
         if (d <= p.at(at)){
            sum += (at + 1) * 100 * d;
            count += d;
         }
      }
      if (sum >= G) {
         mi = min(mi, count);
      }
   }
   return mi;
}
int main() {
   int G = 500;
   vector<int> P = { 3, 5 };
   vector<int> C = { 500, 800 };
   cout << solve(G, P, C) << endl;
}
Salin selepas log masuk

Input

500, { 3, 5 }, { 500, 800 }
Salin selepas log masuk

Output

3
Salin selepas log masuk

Atas ialah kandungan terperinci Program C++ untuk mengetahui bilangan mata minimum yang diperlukan untuk mencapai skor G. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:tutorialspoint.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan