C++程式來找出至少需要多少分才能達到G分的分數
假設我們有兩個陣列p和c,每個陣列都有D個元素,並且還有另一個數字G。考慮在程式設計競賽中,每個問題的分數都基於其難度。問題p[i]的分數為100i。這些p[1] ... p[D]問題是競賽中的所有問題。程式網站上的使用者有一個數字total_score。使用者的total_score是以下兩個元素的和。
基礎分數:解決的所有問題的分數總和
獎勵:當當用戶解決所有分數為100i的問題時,除了基礎分數外,還會獲得完美獎勵c[i]。
Amal是競賽中的新手,還沒有解決任何問題。他的目標是獲得總分G或更多分。我們需要找到他至少需要解決多少問題才能達到這個目標。
因此,如果輸入是G = 500; P = [3, 5]; C = [500, 800],那麼輸出將是3
步驟
#為了解決這個問題,我們將按照以下步驟進行:
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
Example
讓我們看下面的實作以更好地理解−
#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; }
Input
500, { 3, 5 }, { 500, 800 }
輸出
3
以上是C++程式來找出至少需要多少分才能達到G分的分數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

給出以下是一個將羅馬數字轉換為十進制數字的C語言演算法:演算法步驟1-開始步驟2-在運行時讀取羅馬數字步驟3-長度:=strlen(roman)步驟4-對於i=0到長度-1 步驟4.1-switch(roman[i]) 步驟4.1.1-case'm': &nbs

字典序字串比較是指字串依照字典順序進行比較。例如,如果有兩個字串'apple'和'appeal',第一個字串將排在後面,因為前三個字元'app'是相同的。然後對於第一個字串,字元是'l',而在第二個字串中,第四個字元是'e'。由於'e'比'l'短,所以如果我們按照字典順序排列,它將排在前面。在安排之前,字串會按字典順序進行比較。在本文中,我們將看到使用C++進行按字典順序比較兩個字串的不同技術。在C++字串中使用compare()函數C++string物件有一個compare()

煙雨江湖中有著一種家宅玩法,玩家可以自由去建設自己的家宅,而且家宅順利建造之後,也會得到一個家宅分數,同時遊戲內這一家宅分數也是有著其計算方式,當然關於其計算方式也是會透過所給的計算方法去進行計算,玩家也就可以來看看了。煙雨江湖家宅分數計算方法1.家宅分數分:外觀分,放置分,規模分,鑽研分四部分組成2.外觀分:主要是建築皮膚加分和搬家加分(200分),建築皮膚有兩種,一種是上面家宅商店換的手扎,一種是轉盤上面的皮膚手紮3.放置分:製作的出來的家具所獲取的分數,綠色上限10分,藍色上限15分,紫色

在word中插入分數可能有不少人不會操作,畢竟大家不常遇到輸入分數的狀況。但如果遇到就比較麻煩了,所以我們應該要了解Word分數是怎麼輸入的。在word中輸入分數其實很簡單,接下來小編分享word中輸入分數的方法。在Word中輸入分數有多種方法,其中一種是利用插入公式功能。操作步驟如下:開啟Word文件後,點選選單列中的【插入】選項,接著在彈出的選單中選擇【公式】。這樣會打開一個公式編輯器,其中可以輸入想要的分數。在編輯器中,可以使用分數格式按鈕來建立分數,或手動輸入「\frac{分子}{

雙曲函數是使用雙曲線而不是圓定義的,與普通三角函數相當。它從提供的弧度角傳回雙曲正弦函數中的比率參數。但要做相反的事,或者換句話說。如果我們想要根據雙曲正弦值計算角度,我們需要像雙曲反正弦運算一樣的反雙曲三角運算。本課程將示範如何使用C++中的雙曲反正弦(asinh)函數,並使用雙曲正弦值(以弧度為單位)計算角度。雙曲反正弦運算遵循下列公式-$$\mathrm{sinh^{-1}x\:=\:In(x\:+\:\sqrt{x^2\:+\:1})},其中\:In\:是\:自然對數\:(log_e\:k)

連結列表使用動態記憶體分配,即它們相應地增長和收縮。它們被定義為節點的集合。這裡,節點有兩個部分,即資料和鏈路。資料、連結和鍊錶的表示如下-鍊錶的類型鍊錶有四種類型,如下:-單鍊錶/單鍊錶雙/雙向鍊錶循環單鍊錶循環雙鍊錶我們使用遞歸方法求鍊錶長度的邏輯是-intlength(node *temp){ if(temp==NULL) returnl; else{&n

映射是C++中的一種特殊類型的容器,其中每個元素都是一對兩個值,即鍵值和映射值。鍵值用於索引每個項目,映射值是與鍵關聯的值。無論映射值是否唯一,鍵始終是唯一的。要在C++中列印映射元素,我們必須使用迭代器。一組項目中的一個元素由迭代器物件指示。迭代器主要與陣列和其他類型的容器(例如向量)一起使用,並且它們具有一組特定的操作,可用於識別特定範圍內的特定元素。可以增加或減少迭代器來引用範圍或容器中存在的不同元素。迭代器指向範圍內特定元素的記憶體位置。使用迭代器在C++中列印地圖首先,我們先來看看如何定義

rename函數將檔案或目錄從舊名稱變更為新名稱。此操作類似於移動操作。因此,我們也可以使用此rename函數來移動檔案。此函數存在於stdio.h庫頭檔中。 rename函數的語法如下:intrename(constchar*oldname,constchar*newname);rename()函數的函數它接受兩個參數。一個是oldname,一個是newname。這兩個參數都是指向常數字元的指針,用於定義檔案的舊名稱和新名稱。如果檔案重新命名成功,則傳回零;否則,傳回非零整數。在重新命名操作期間
