PHP动态规划解决0-1背包问题实例分析_php技巧
本文实例分析了PHP动态规划解决0-1背包问题。分享给大家供大家参考。具体分析如下:
背包问题描述:一个承受最大重量为W的背包,现在有n个物品,每个物品重量为t, 每个物品的价值为v。
要使得这个背包重量最大(但不能超过W),同时又需要背包的价值最大。
思路:定义一个二维数组,一维为物品数量(表示每个物品),二维是重量(不超过最大,这里是15),下面数组a,
动态规划原理思想,max(opt(i-1,w),wi+opt(i-1,w-wi)) 当中最大值,
opt(i-1,w-wi)指上一个最优解
<?php //这是我根据动态规划原理写的 // max(opt(i-1,w),wi+opt(i-1,w-wi)) //背包可以装最大的重量 $w=15; //这里有四件物品,每件物品的重量 $dx=array(3,4,5,6); //每件物品的价值 $qz=array(8,7,4,9); //定义一个数组 $a=array(); //初始化 for($i=0;$i<=15;$i++){ $a[0][$i]=0; } for ($j=0;$j<=4;$j++){ $a[$j][0]=0; } //opt(i-1,w),wi+opt(i-1,w-wi) for ($j=1;$j<=4;$j++){ for($i=1;$i<=15;$i++){ $a[$j][$i]=$a[$j-1][$i]; //不大于最大的w=15 if($dx[$j-1]<=$w){ if(!isset($a[$j-1][$i-$dx[$j-1]])) continue; //wi+opt(i-1,wi) $tmp = $a[$j-1][$i-$dx[$j-1]]+$qz[$j-1]; //opt(i-1,w),wi+opt(i-1,w-wi) => 进行比较 if($tmp>$a[$j][$i]){ $a[$j][$i]=$tmp; } } } } //打印这个数组,输出最右角的值是可以最大价值的 for ($j=0;$j<=4;$j++){ for ($i=0;$i<=15;$i++){ echo $a[$j][$i]."/t"; } echo "/n"; } ?>
希望本文所述对大家的php程序设计有所帮助。

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

To work on file upload we are going to use the form helper. Here, is an example for file upload.

In this chapter, we are going to learn the following topics related to routing ?

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

Validator can be created by adding the following two lines in the controller.

Working with database in CakePHP is very easy. We will understand the CRUD (Create, Read, Update, Delete) operations in this chapter.
