举例说明,动态规划和贪心算法的区别
贪心算法是种策略,思想。
。
。
它并没有固定的模式比如最简单的背包问题用贪心的思想去做,就可能有很多种方法性价比最高的、价值最高的、重量最轻的而你没法确保你所选择的贪心策略对所有的情况都是绝对最优的动态规划的思想是分治+解决贪心算法的证明方法
贪心算法的基本思路如下:
1.建立数学模型来描述问题。
2.把求解的问题分成若干个子问题。
3.对每一子问题求解,得到子问题的局部最优解。
4.把子问题的解局部最优解合成原来解问题的一个解。
----------------------------------------------
其实归纳起来也就一个类。
其他的都是分支求一个算法(贪心算法)
首先,无所谓哪里密集哪里不密集的说法,这是人为的区分,需要首先遍历全部格子才能确定,是最慢的算法,全部遍历过了就可以得出最优的路线了.
既然用贪心算法,为了思考方便,可以假设棋盘无穷大,算法的目的是判断下一步该往右走还是往下走,思想如下:
判断当前格子右、下两个相邻的格子是否有金块,情形如下:
1)如果一个有一个没有,则往有金块的格子走
2)如果都没有或都有,则需要判断往哪个方向走能更快的拾到下一个金块,方法如下:
让机器人假设地各往两个方向走一步,然后对当前格子作判断情形如下:
A)一个格子继续走能拾到金块,另一个不能,则上一步往该格子走
B)如果仍旧都有或都没有,重复2)直到找到符合A)的情形。
假设棋盘是N*N个格子,则贪心算法最坏的情形是要遍历整个棋盘,比如只有第一个格子有金块时,就需要遍历整个棋盘才能确定走法。
最好的情形也需要遍历4*N个格子。
时间复杂度上来算的话,应该是O(nLogn)贪心算法编程
复杂度自己推吧,很简单
#include <stdio.h>
void maxmoney(unsigned int cost, int* a);
int main()
{
unsigned int cost, i, j;
int a[6]={0,0,0,0,0,0};
printf("%s","Cost: ");
scanf("%d",&cost);
maxmoney(cost, a);
printf("
");
printf("100 yuan : %d
",a[0]);
printf("50 yuan : %d
",a[1]);
printf("10 yuan : %d
",a[2]);
printf("5 yuan : %d
",a[3]);
printf("2 yuan : %d
",a[4]);
printf("1 yuan : %d
",a[5]);
return 0;
}
void maxmoney(unsigned int cost, int* a)
{
if (cost < 2){
a[5] += cost;
}else if (cost >= 100){
a[0]++;
cost = cost - 100;
maxmoney(cost, a);
}else if (cost >= 50){
a[1]++;
cost = cost - 50;
maxmoney(cost, a);
}else if (cost >= 10){
a[2]++;
cost = cost - 10;
maxmoney(cost,a);
}else if (cost >= 5){
a[3]++;
cost = cost - 5;
maxmoney(cost, a);
}else if (cost >= 2){
a[4]++;
cost = cost - 2;
maxmoney(cost, a);
}
}如何用贪心算法求解tsp问题
最快回答那个不懂别乱说,别误人子弟。
这题标准的贪心算法,甚至很多时候被当做贪心例题
要求平均等待时间,那么就得用 总等待时间 / 人数
所以只用关心总等待时间,
如果数据大的在前面,那么后面必然都要加一次这个时间,所以按从小到大排。
给你写了个,自己看吧。
#include "stdafx.h"
#include
#include
#include
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
int n;
float arr[105];
cin >> n;
for(int i = 0; i < n; ++i)
cin >> arr[i];
sort(arr, arr+n);
int tnow = 0;
int tmax = 0;
for(int i = 0; i < n; ++i)
{
tmax += tnow;
tnow += arr[i];
}
for(int i = 0; i < n; ++i)
{
printf("%0.2f ", arr[i]);
}
cout << endl;
printf("%0.2f
",tmax / (float)n);
return 0;
}
百驰云成立于2017年,是一家新国人IDC商家,且正规持证IDC/ISP/CDN,商家主要提供数据中心基础服务、互联网业务解决方案,及专属服务器租用、云服务器、云虚拟主机、专属服务器托管、带宽租用等产品和服务。百驰云提供源自大陆、香港、韩国和美国等地骨干级机房优质资源,包括BGP国际多线网络,CN2点对点直连带宽以及国际顶尖品牌硬件。专注为个人开发者用户,中小型,大型企业用户提供一站式核心网络云端...
HostKvm是一家成立于2013年的国外主机服务商,主要提供基于KVM架构的VPS主机,可选数据中心包括日本、新加坡、韩国、美国、中国香港等多个地区机房,均为国内直连或优化线路,延迟较低,适合建站或者远程办公等。本月商家针对全场VPS主机提供8折优惠码,优惠后美国洛杉矶VPS月付5.2美元起。下面列出几款不同机房VPS主机产品配置信息。套餐:美国US-Plan0CPU:1cores内存:1GB硬...
7月4日是美国独立日,大致就是国庆节的意思吧。hostodo今年提前搞了个VPS大促销活动,4款便宜VPS,相当于7折,续费不涨价,本次促销不定时,不知道有多少货,卖完为止。VPS基于KVM虚拟,NVMe阵列,1Gbps带宽,自带一个IPv4+/64 IPv6,solusvm管理,送收费版DirectAdmin授权,VPS在用就有效! 官方网站:https://www.hostodo.com ...
贪心算法为你推荐
现代通信原理:电路分析、电子技术、高频电路、微波天线、现代通信原理、船用无线电通信设备、船舶无线电导航设备、网站推广120种方法如何把自己公司的网站推广开?数据库系统概论大二学了《数据库系统概论》这本书,请问可以考计算机三级数据库吗?声源定位大脑皮层中央后回和中央前回分别对应什么中枢?新中大软件我公司准备上一套财务软件,新中大的财务软件怎么样啊?象形文字图片象形字举例番禺网站优化广州网站优化的公司网站优化最最专业的哪家寻找手机怎么用手机序列号找回手机?cmnet设置怎么设置CMNET接入点?机柜生产厂中国生产机箱机柜最大的最集中的地方在哪?
中国互联网域名注册 cn域名注册 美国linux主机 美国主机网 服务器日志分析 tightvnc 国内加速器 电子邮件服务器 佛山高防服务器 服务器硬件防火墙 多线空间 电信托管 英雄联盟台服官网 稳定空间 腾讯数据库 云服务是什么意思 存储服务器 国外免费网盘 贵州电信 九零网络 更多