计算机算法分析与设计(15)---贪心算法(虚拟汽车加油问题和最优分解问题)

文章目录


一、虚拟汽车加油问题

1.1 问题描述

 一辆虚拟汽车加满油后可行驶 n n n km。旅途中有若干加油站。设计一个有效算法,指出应在哪些加油站停靠加油,使沿途加油次数最少,计算最少加油次数。

数据输入:
第一行有两个整数n和k,表示汽车加满油后可行驶n km,且路途中有k个加油站。接下来的一行中有k+1个整数,表示第k个加油站与k-1个加油站之间的距离。第0个加油站表示处出发地,汽车已加满油,第k+1个加油站便是目的地。
数据输出:
将计算的最少加油次数输出,如果无法到达目的地,则输出 “No Solution”。

1.2 思路分析

 贪心策略:只要汽车能赶到下一个加油站,就不用加油;否则在当前加油站加满油再出发。

1.3 代码编写

样例输入:
7 7
1 2 3 4 5 1 6 6
样例输出:
4

在这里插入图片描述

#include<bits/stdc++.h>
using namespace std;
 
int main(){
	int n,k;
	cin>>n>>k;
	
	int a[k+1];
	for(int i=0; i<k+1; i++){
		cin>>a[i];
	}
		
	bool f=0;
	int sum=0,gas=n; //gas表示当前的油还可以走多少km
	for(int i=0; i<k+1; i++)
	{
		if(n<a[i])//出现两个加油站之间距离大于n则肯定到达不了目的地 
		{
			f=1;
		}
		if(gas<a[i])//当前的油不够行驶 
		{
			sum++; 
			gas=n;
		}
		gas=gas-a[i];
	}
	
	if(f)
	{
		cout<<"No Solution\n";
	}
	else
	{
		cout<<"最少加油次数:"<<sum<<endl;
	}
	return 0;
}

在这里插入图片描述

二、最优分解问题

2.1 问题描述

 设 n n n 是一个正整数。现在要求将 n n n 分解为若干互不相同的自然数的和,且使这些自然数的乘积最大。

数据输入:
输入一个正整数n。
数据输出:
输出计算得出的最大乘积。

2.2 思路分析

 1. 整数的一个性质:若 a + b = N ( 常数 ) a + b =N(常数) a+b=N(常数),则 ∣ a − b ∣ | a - b | ab 越小, a ∗ b a * b ab 越大

 2. 分析: n n n 为整数相加之和,常数不变。 ( a + b ) 2 = ( a − b ) 2 + 4 a b = n 2 — > a b = ( n 2 − ( a − b ) 2 ) / 4 (a+b)^2 = (a-b)^2 +4ab =n^2 —> ab=(n^2 -(a-b)^2)/4 a+b)2=(ab)2+4ab=n2>ab=(n2(ab)2)/4;所以若 a + b = 常数 a+b=常数 a+b=常数,则 a − b a-b ab 的绝对值越小, a b ab ab 值越大。

 3. 思路:因为要使乘积最大,所以要尽量分解为相似大小的数。分解时,因数从 2 2 2 开始,每次加 1 1 1 n = n − a [ i ] n=n-a[i] n=na[i],保证剩下的数比下一次的数大。
 所以最优分解为从 2 2 2 开始连续的自然数最好,最终分解剩余了一个余数,从分解的最后项依次加 1 1 1 即可(这样乘积中大的数会更大,总的乘积会更大)。

 4. 例如:分解 13 13 13 分解为 2 、 3 、 4 2、3、4 234,还剩下 4 4 4,不够继续分解的下一个数 5 5 5,就把 4 4 4 依次分配给前面的因子,分配顺序是 4 = > 3 = > 2 4 => 3 => 2 4=>3=>2。所以最终结果为 3 、 4 、 6 3、4、6 346,这就是最大乘积的因子。(分配顺序为从大到小,如果还剩下,就继续分配,直到分完变为 0 0 0 为止)。

2.3 代码编写

样例输入:
10
样例输出:
30

#include<iostream>
using namespace std;

int main()
{
    int a[100];
    int n,i=1,j;
    int sum=1;     
    cin>>n;
    
    a[0]=2;
    n=n-a[0];
    while(n>a[i-1]) //a[i-1]=2
    {
        a[i]=a[i-1]+1; //第二个因子是3,往后依次...... 
        n=n-a[i];
        i++;
    }
 
    while(n>0) //余数依次减1,加在已分配好的因子上
    {
        for(j=0;j<i;j++)
        {
            a[i-j-1]++; //从最大的数开始加1
            n--;        //余数减1 
            if(n==0)    //若n不等于0,继续执行下一轮分配 
            {
			    break;
			}  
        }
    }
 
    j=0;
    while(j<i) //求最终的乘积
    {
        sum=sum*a[j];
        j++;
    }
    cout<<sum;
    return 0;
}

在这里插入图片描述


http://www.niftyadmin.cn/n/5109111.html

相关文章

黑豹程序员-架构师学习路线图-百科:开启分布式架构开发先河,让Java戴上全球第一的皇冠-EJB

文章目录 1、EJB的传奇2、什么是 EJB3、从拥抱到抛弃4、最终版EJB3.0 1、EJB的传奇 EJB这项技术其实已经消亡了&#xff0c;但为何我还专门单另拿出来讲呢&#xff1f;原因有三。 第一、EJB是J2EE雄霸全球的功臣&#xff0c;它把我们编程推向了分布式架构开发&#xff0c;为开…

【软考-中级】系统集成项目管理工程师-人力资源管理历年案例

持续更新。。。。。。。。。。。。。。。 目录 2019 下 试题三(20分)背诵整理1. 冲突管理的6种方法2. 获取项目人力资源的依据 系列文章 2019 下 试题三(20分) 阅读下列说明&#xff0c;回答问题 1至问题 3&#xff0c;将解答填入答题纸的对应栏内     某公司承接了一个软件…

Java RestTemplate使用TLS1.0(关闭SSL验证)

1. 问题 使用RestTemplate调用Http API时&#xff0c;服务器是TLS1.0&#xff0c;但是客户端Java默认禁止TLS1.0&#xff0c;会报错&#xff1a;org.springframework.web.client.ResourceAccessException: I/O error on POST request for “https://10.255.200.114/health”: …

2023年中国轮胎模具需求量、竞争格局及行业市场规模分析[图]

轮胎模具是轮胎生产线中的硫化成形装备&#xff0c;是高技术含量、高精度及高附加值的个性化模具产品&#xff0c;尤其是轮胎的花纹、图案、字体以及其他外观特征的成形都依赖于轮胎模具&#xff0c;因此其制造技术难度较高。其主要功能是通过所成型材料&#xff08;主要是橡塑…

SpringBoot常见异步编程,你会多少?

微信公众号访问地址&#xff1a;SpringBoot常见异步编程&#xff0c;你会多少&#xff1f; 近期热推文章&#xff1a; 1、springBoot对接kafka,批量、并发、异步获取消息,并动态、批量插入库表; 2、SpringBoot用线程池ThreadPoolTaskExecutor异步处理百万级数据; 3、基于Redis…

甄知科技张礼军:数智化转型助企业破茧成蝶!

数智化浪潮滚滚向前&#xff0c;正席卷各行各业&#xff0c;带领企业从数字化时代跨入数智化时代。可什么是数智化&#xff1f;如何实现数智化转型&#xff1f;已经成为横亘在无数企业面前的大难题&#xff01; 事实上&#xff0c;数智化是数字化、AI和业务三个要素的交集&…

TikTok Shop美国本土店VS跨境店,浅析与选择

TikTok不仅仅是一个用于分享有趣短视频的平台&#xff0c;它也逐渐成为了商家们极力推广自己品牌和产品的场所。 在TikTok的商业生态系统中&#xff0c;存在几种不同的商店类型&#xff0c;各有其独特性和适用场景。今天&#xff0c;我们就来深入探讨这些店的差异与特点。 一、…

YOLOv5算法改进(15)— 如何去更换Neck网络(包括代码+添加步骤+网络结构图)

前言:Hello大家好,我是小哥谈。在学习完了如何去更换主干网络之后,接着就让我们通过案例的方式去学习下如何去更换Neck网络。本篇文章的特色就是比较浅显易懂,附加了很多的网络结构图,通过结构图的形式向大家娓娓道来,希望大家学习之后能够有所收获!🌈 前期回顾: YO…