日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

国王与金矿

發布時間:2025/4/16 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 国王与金矿 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

自從受傷之后好久都打不起精神,好在今天垚哥提醒了我,讓我一個人的時候就專心學習,跟朋友在一起的時候再玩。確實,一個人玩容易抑郁。

現在記錄一下國王與金礦的編程題目:

有一個國家發現了5座金礦,每座金礦的黃金儲量不同,需要參與挖掘的工人數也不同。參與挖礦工人的總數是10人。每座金礦要么全挖,要么不挖,不能派出一半人挖取一半金礦。要求用程序求解出,要想得到盡可能多的黃金,應該選擇挖取哪幾座金礦?

?gold[] = {400, 500, 200, 300, 350};?people[] = {5, 5, 3, 4, 3};

第一種就是暴力求解法,每一個金礦只有挖或者不挖的可能,一共2的n次方種情況;再把每種情況是否有員工不足篩選出來,最后求最大值。這種方法我試試自己用C++和Java寫一下

package com.cai.javase.test國王與金礦;public class MostGold0 {public static int Violence( int n, int worker, int[] gold, int [] people ) {/*** k是相當于二進制01011,反向表示每一塊金礦是否挖掘* g是挖得的金礦* p是用的人數*/int maxgold = 0, k, g, p;for ( int i = 0; i < Math.pow ( 2 ,n ); i++ ) {k = i; g = 0; p = 0;for( int j = 0; j < n; j++ ) {if( k % 2 == 1 ) {//如果最后一位是1,則挖這塊礦石g += gold[j];p += people[j];}k = k / 2;//二進制轉換,右移一位 }if( p <= worker && g > maxgold)//如果用的人小于總人數且挖的金子大于最大金礦maxgold = g;}return maxgold;}public static void main(String[] args) {// TODO Auto-generated method stubint[] gold = {400, 500, 200, 300, 350};int[] people = {5, 5, 3, 4, 3};System.out.println(Violence(5, 10, gold, people));}}

好吧,其實自己還是不會寫,還是借鑒了網上的代碼

下面用C++再寫一遍:

#include<iostream> #include<math.h>using namespace std;int Violence ( int n, int worker, int Gold[], int People[]);int main(){int gold[] = {400, 500, 200, 300, 350};int people[] = {5, 5, 3, 4, 3};cout << Violence(5, 10, gold, people) << endl; }int Violence ( int n, int worker, int Gold[], int People[]){/*** k是相當于二進制01011,反向表示每一塊金礦是否挖掘* g是挖得的金礦* p是用的人數*/int k, maxGold, g, p;for( int i = 0; i < pow( 2 , n ); i++){k = i; g = 0; p = 0;for( int j = 0; j < n; j++){if ( k % 2 == 1 ){//如果最后一位是1,則挖這塊礦石g += Gold[j];p +=People[j];}k /= 2;//二進制轉換,右移一位}if ( p <= worker && g > maxGold)//如果用的人小于總人數且挖的金子大于最大金礦maxGold = g;}return maxGold; }

?

?

如果不在main函數前定義violence函數則會出現以下error: `Violence' was not declared in this scope|

如果不在頭文件加上math.h則會出現error: `pow' was not declared in this scope|,因為有pow函數

下面是遞歸算法,也就是算最后一塊挖和不挖所能得到的最大金礦;先把java代碼抄上來:

package com.cai.javase.test國王與金礦;public class MostGold {public static void main(String[] args) {// TODO Auto-generated method stubint[] gold = {400, 500, 200, 300, 350};int[] people = {5, 5, 3, 4, 3};System.out.println(getMostGold(5, 10, gold, people));}public static int getMostGold(int n, int worker, int[] g, int[] p) {if ( n > g.length )//n超過了金礦數System.out.println("fOQ");if ( n <= 1 && worker < p[0])//一個金礦沒工人挖了return 0;if ( n == 1 && worker >= p[0])//一個金礦有工人return g[0];if ( n > 1 && worker < p[n - 1])//不是第一塊,但是工人挖不了這一塊了,因為人不夠return getMostGold(n - 1, worker, g, p);return Math.max(getMostGold(n - 1, worker, g, p),(getMostGold(n - 1, worker - p[n - 1], g, p) + g[n - 1]));} }

再改成C++ 代碼:

#include<iostream> #include<cmath> using namespace std; int MostGold(int n, int goldNum, int worker, int Gold[], int people[]){ // cout << "正在挖第" << n << "塊金子" << endl;if ( n > goldNum )cout<<"FoQ That man!"<<endl;if ( n <= 1 && worker < people[0]){return 0;// cout << "第一塊金礦沒工人挖了返回0" << endl; }if ( n <= 1 && worker >= people[0]){return Gold[0];// cout << "有工人挖就返回第一塊金礦的金子數" << endl; }if ( n > 1 && worker < people[n - 1]){return MostGold( n - 1, goldNum, worker, Gold, people );// cout << "不是第一塊金子且人數足夠挖這塊,返回不挖這塊能得到的最大金子數" << endl; }int a = MostGold( n - 1, goldNum, worker, Gold, people);//不挖最后一塊所能得到的最大金子數int b = MostGold( n - 1, goldNum, worker - people[n - 1], Gold, people) + Gold [n - 1];//挖最后一塊所能得到的最大金子數// if( a > b ) // cout << "不挖這一塊" << endl; // else // cout << "挖出了第" << n << "塊金子" << endl;return max( a, b ); }int main(){int gold[] = {400, 500, 200, 300, 350};//20 cout << sizeof(gold) << endl;//5 cout << sizeof(gold) / sizeof(gold[0]) << endl;int people[] = {5, 5, 3, 4, 3};int GoldNum = sizeof(gold) / sizeof(gold[0]);cout << MostGold(5, GoldNum, 10, gold, people) << endl << endl; // cout << gold << endl << people << endl; }

java中的求數組長度函數是.lengh而C++中的是sizeof()

改的時候發現了數組傳入函數之后用sizeof就測不出長度了,int類型的數組的sizeof永遠是4,所以要在傳入函數之前就把數組的長度求出來再放進函數。

而且不知道為什么要在最后加兩個endl或者最后一行不注解掉才能顯示出900,而且不加上就會變成病毒被殺。

int Violence ( int n, int worker, int Gold[], int People[])

轉載于:https://www.cnblogs.com/caiziqi/p/11454399.html

總結

以上是生活随笔為你收集整理的国王与金矿的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 丰满少妇在线观看资源站 | 国产老熟妇精品观看 | 校园春色 亚洲色图 | 成人免费av网站 | 天天爽天天爽夜夜爽毛片 | 国产一级全黄 | 亚洲最大中文字幕 | 懂色一区二区三区免费观看 | 日韩激情视频在线观看 | 成人p站在线观看 | 精品人妻一区二区三区免费 | 精品一区二区三区免费视频 | 国产a网站| 三级亚洲 | 日日噜噜噜噜人人爽亚洲精品 | 69精品人人 | 超碰人人人人人人 | 日本亚洲综合 | 欧美成人69 | 91九色视频 | 国产亚洲精品美女久久久久 | 超碰p| 九九热在线观看 | 九九在线观看视频 | 中文字幕第页 | 爱爱视频网站免费 | 久久精品国产精品亚洲毛片 | 女人的洗澡毛片毛多 | 国产免费麻豆 | 色爽爽爽爽爽爽爽爽 | 成人片在线免费看 | 96在线视频 | 久久亚洲精品无码va白人极品 | 五月婷婷久久综合 | 人妻少妇偷人精品久久性色 | 男生和女生一起搞鸡 | 丝袜美女被c | 国产亚洲精品美女 | 特黄视频在线观看 | 色呦呦影院 | 91久久久久久久久久久久久 | 亚洲免费黄网 | 大尺度做爰呻吟舌吻情头 | 久久久亚洲精品视频 | 亚洲欧美不卡 | 久久美女视频 | 又黄又爽的视频在线观看 | 成人在线免费网站 | 国产精品免费在线播放 | a片在线免费观看 | 美女av网址 | 日本少妇在线观看 | 强伦轩人妻一区二区电影 | 牛av在线| 国内偷拍精品视频 | 北条麻妃一区二区三区在线观看 | 少妇极品熟妇人妻无码 | 日本女人一区二区三区 | 成人免费看aa片 | 一级坐爱片| 日本韩国在线播放 | 日本三级视频 | 男男啪啪无遮挡 | 丁香激情婷婷 | 国产精品美女久久久 | 国产肥白大熟妇bbbb视频 | 香蕉视频污在线观看 | 国产精品久久久久久免费免熟 | 亚洲免费视频网站 | 69堂视频 | 国产日韩三级 | 男人用嘴添女人下身免费视频 | 啪啪亚洲| 亚洲欧美日本国产 | 豆花av在线| 福利片在线播放 | 在线电影一区二区三区 | 国产av自拍一区 | 高h校园不许穿内裤h调教 | 亚洲一级片网站 | 亚洲精品国产精品乱码 | 青青色在线视频 | 老司机午夜视频 | 日本伊人色 | 天天久久综合网 | 乱岳 | 伊人影院综合 | 九九热在线免费视频 | 久久人人看 | 亚洲第一在线播放 | 午夜成人在线视频 | 午夜av中文字幕 | 天天视频天天爽 | 欧美激情va永久在线播放 | 日韩一级理论片 | 久久国产精品免费视频 | 国产一级aa大片毛片 | 性一交一乱一色一免费无遮挡 | 欧美壮男野外gaytube |