亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語言背包問題求解全過程(貪心方法)

 更新時間:2024年06月13日 09:12:25   作者:渙清。  
背包問題是一個經(jīng)典的動態(tài)規(guī)劃問題,而貪心算法是一種常用的解決背包問題的方法,這篇文章主要給大家介紹了關于C語言背包問題求解(貪心方法)的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下

問題描述:

  • 有一個背包,背包容量是M=150。有7個物品,物品可以分割成任意大小。要求盡可能讓裝入背包中的物品總價值最大,但不能超過總?cè)萘俊?/li>
  • 物品:A    B    C    D    E    F    G
  • 重量:35  30   60  50   40  10  25
  • 價值:10  40   30  50   35  40  30

算法描述:

貪心算法(又稱貪婪算法)是指,在對問題求解時,總是做出在當前看來是最好的選擇。也就是說,不從整體最優(yōu)上加以考慮,他所做出的是在某種意義上的局部最優(yōu)解。

貪心算法不是對所有問題都能得到整體最優(yōu)解,關鍵是貪心策略的選擇,選擇的貪心策略必須具備無后效性,即某個狀態(tài)以前的過程不會影響以后的狀態(tài),只與當前狀態(tài)有關。

問題分析:

1.目標函數(shù): ∑pi最大,使得裝入背包中的所有物品pi的價值加起來最大。

2.約束條件:裝入的物品總重量不超過背包容量:∑wi<=M( M=150)

3.貪心策略: 選擇單位重量價值最大的物品

算法設計:

  • 計算出每個物品單位重量的價值
  • 按單位價值從大到小將物品排序
  • 根據(jù)背包當前所剩容量選取物品
  • 如果背包的容量大于當前物品的重量,那么就將當前物品裝進去。否則,那么就將當前物品分割再裝進去,然后跳出循環(huán)結束。

代碼實現(xiàn):

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1000;
float z[maxn];
 
void Sort(int n,float w[],float v[]){
	for(int i=0;i<n;i++)
		z[i]=v[i]/w[i];//用z[]存物品的單位重量價值 
	for(int i=0;i<n;i++){//此排序的策略是每次把單位重量物品的價值最大的物品放在前面 
		for(int j=i+1;j<n;j++){
			if(z[i]<z[j]){
				float temp = z[i];
				z[i] = z[j];
				z[j]=temp;
				float tempw = w[i];
				w[i] = w[j];
				w[j] = tempw;
				float tempv = v[i];
				v[i] = v[j];
				v[j] = tempv; 
			}
		}
	}
}
 
void fire(int n,float w[],float v[],float x[],float pimax){
	Sort(n,w,v);//根據(jù)單位重量物品的價值對物品進行排序 
	int i;
	for(i=0;i<n;i++){
		if(w[i]>pimax)	break;
		x[i] = 1;	//x[]數(shù)組用來記錄此次是否選擇物品,1代表全部拿走,0代表不拿,小數(shù)代表部分拿 
		pimax -= w[i];
	}
	if(i<=n-1)  x[i] = pimax/w[i]; 
} 
 
 
int main(){
	int n;
	float pi=0; 
	float pimax,v[maxn],w[maxn],x[maxn];//w[],每個物品的重量,v[]代表每個物品的價值,pimax代表最大容量 
	memset(x,0,sizeof(x));
	cout<<"請輸入最大容量:";
	cin>>pimax;
	cout<<"請輸入物品(物品可以任意分割)數(shù)量:";
	cin>>n;
	cout<<"請輸入每個物品的重量和價值:"<<endl;
	for(int i=0;i<n;i++){
		cin>>w[i]>>v[i];
	}
	fire(n,w,v,x,pimax);
	for(int i=0;i<n;i++){
		if(x[i]==1){
			pi+=v[i];
		}
		else{
			pi+=v[i]*x[i];
		}
	}
	cout<<"最終收獲的物品(物品可以任意分割)價值為:"<<pi<<endl;
	return 0;
}

運行結果:

總結

到此這篇關于C語言背包問題求解(貪心方法)的文章就介紹到這了,更多相關C語言背包問題內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • C++設計模式迪米特法則實例

    C++設計模式迪米特法則實例

    這篇文章主要為大家詳細介紹了C++設計模式迪米特法則實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • C語言實現(xiàn)簡單通訊錄系統(tǒng)

    C語言實現(xiàn)簡單通訊錄系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)簡單通訊錄系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • opencv利用霍夫變換檢測直線進行圖片校正

    opencv利用霍夫變換檢測直線進行圖片校正

    這篇文章主要為大家詳細介紹了opencv利用霍夫變換檢測直線對圖片進行校正,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • C++超詳細講解樹與二叉樹

    C++超詳細講解樹與二叉樹

    在之前的文章里,我們學習的一直是一對一的線性結構,可現(xiàn)實中,還有很多一對多的情況需要處理,所以我們需要研究這樣一種一對多的數(shù)據(jù)結構——樹
    2022-05-05
  • C++實現(xiàn)打印兩個有序鏈表公共部分的方法

    C++實現(xiàn)打印兩個有序鏈表公共部分的方法

    這篇文章主要介紹了C++實現(xiàn)打印兩個有序鏈表公共部分的方法,涉及C++針對有序鏈表的簡單遍歷、比較相關操作技巧,需要的朋友可以參考下
    2017-05-05
  • C++單一職責原則示例代碼淺析

    C++單一職責原則示例代碼淺析

    我們在設計一個類時要學會發(fā)現(xiàn)職責,并把那些職責相互分離,其實要去判斷是否應該分離出一個類來并不難,前面說過,一個類應該只有一個引起它變化的原因,如果你能想到其它的原因也能去改變這個類,那么這個類就具有多于1個的職責,就應該考慮類的職責分離
    2023-02-02
  • C++超詳細講解模擬實現(xiàn)vector

    C++超詳細講解模擬實現(xiàn)vector

    這篇文章主要介紹了C++ 容器 Vector 的使用方法,Vector 是一個能夠存放任意類型的動態(tài)數(shù)組,有點類似數(shù)組,是一個連續(xù)地址空間,下文更多詳細內(nèi)容的介紹,需要的小伙伴可以參考一下
    2022-07-07
  • C++詳細講解繼承與虛繼承實現(xiàn)

    C++詳細講解繼承與虛繼承實現(xiàn)

    這篇文章主要介紹了Java中的繼承詳情,繼承是面向?qū)ο笕筇卣髦唬梢允沟米宇惥哂懈割惖膶傩院头椒?,還可以在子類中重新定義,以及追加屬性和方法,下文介紹需要的朋友可以參考下
    2022-04-04
  • C++實現(xiàn)掃雷經(jīng)典小游戲

    C++實現(xiàn)掃雷經(jīng)典小游戲

    這篇文章主要為大家詳細介紹了C++實現(xiàn)掃雷經(jīng)典小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 一文弄懂C語言EOF

    一文弄懂C語言EOF

    在 C語言中,EOF 是一個宏定義,EOF 常常用于文件的輸入輸出中,當讀取到文件結束時,會返回 EOF,本文就詳細的介紹一下具體使用方法,感興趣的可以一起來了解一下
    2023-05-05

最新評論