freepeople性欧美熟妇, 色戒完整版无删减158分钟hd, 无码精品国产vα在线观看DVD, 丰满少妇伦精品无码专区在线观看,艾栗栗与纹身男宾馆3p50分钟,国产AV片在线观看,黑人与美女高潮,18岁女RAPPERDISSSUBS,国产手机在机看影片

正文內(nèi)容

dqsscha清華大學acm集訓隊培訓資料-資料下載頁

2025-06-25 06:33本頁面
  

【正文】 f(a, k+1, n)。 } else { work(a, n)。 }}void work(bool a[], int n){ int x。 int time=0, score=0。 for (x=0。 xn。 x++) { if (a[x]) { score += t[x][1]。 time += t[x][0]。 } } if (time = tSum) { if (score m) { m = score。 } }}int main(void){ bool a[30]。 int n, c。 cinntSum。 m = 0。 for (c=0。 cn。 c++) { cint[c][0]。 cint[c][1]。 } f(a, 0, n)。 coutmendl。 return 0。}通過一個排列生成器將所有的可能送入work()函數(shù)內(nèi),然后work函數(shù)找到在時間范圍內(nèi)的最高的分數(shù)?,F(xiàn)在我們將其優(yōu)化,將work()和f()合并,就能得到更好的程序includeiostreamusing namespace std。int m。int t[20][2]。int tSum。void dfs(int k, int n, int cScore, int cTime){ if (k n) { dfs(k+1, n, cScore , cTime)。 dfs(k+1, n, cScore + t[k][1], cTime + t[k][0])。 } else { if (cTime = tSum) { if (cScore m) { m = cScore。 } } }}int main(void){ int n, c。 cinntSum。 m = 0。 for (c=0。 cn。 c++) { cint[c][0]。 cint[c][1]。 } dfs(0, n, 0, 0)。 coutmendl。 return 0。}這個程序就是深度優(yōu)先搜索,如果n非常大,遞歸調(diào)用的次數(shù)是非常驚人的,達到次。為了減少遞歸的次數(shù),我們可以采取剪枝的手段,在遞歸下一次前判斷是否可行。如果肯定不能就停止遞歸,節(jié)省時間。includeiostreamusing namespace std。int m。int t[20][2]。int tSum。void dfs(int k, int n, int cScore, int cTime){ if (k n) { dfs(k+1, n, cScore , cTime)。 if (cTime tSum) { dfs(k+1, n, cScore + t[k][1], cTime + t[k][0])。 } } else { if (cTime = tSum) { if (cScore m) { m = cScore。 } } }}int main(void){ int n, c。 cinntSum。 m = 0。 for (c=0。 cn。 c++) { cint[c][0]。 cint[c][1]。 } dfs(0, n, 0, 0)。 coutmendl。 return 0。}為了達到更好的剪枝效果,可以在搜索前對數(shù)據(jù)進行排序。競賽真理原題也可用這種思想去解。更復雜的算法將在以后進行講解.
點擊復制文檔內(nèi)容
范文總結(jié)相關推薦
文庫吧 www.dybbs8.com
備案圖鄂ICP備17016276號-1