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

文章目录

  • 一、虚拟汽车加油问题
    • 1.1 问题描述
    • 1.2 思路分析
    • 1.3 代码编写
  • 二、最优分解问题
    • 2.1 问题描述
    • 2.2 思路分析
    • 2.3 代码编写


一、虚拟汽车加油问题

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表示当前的油还可以走多少kmfor(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]++; //从最大的数开始加1n--;        //余数减1 if(n==0)    //若n不等于0,继续执行下一轮分配 {break;}  }}j=0;while(j<i) //求最终的乘积{sum=sum*a[j];j++;}cout<<sum;return 0;
}

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/114806.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MyBatisPlus实现连表操作、批量处理

1、实现连表查询 正常来说单靠mybatisplus无法实现连表查询&#xff0c;只能靠单表sql然后进行拼接形成连表查询&#xff0c;或者使用xml文件去编写sql语句来实现连表查询。但他又给我们提供了一个插件MyBatis-Plus-Join&#xff0c;用来弥补mybatisplus再连表上的不足&#…

Apache Jmeter测压工具快速入门

Jmeter测压工具快速入门 一、Jmeter介绍二、Jmeter On Mac2.1 下载2.2 安装2.2.1 环境配置2.2.2 初始化设置 2.3 测试2.3.1 创建JDBC Connection Configuration2.3.2 创建线程组2.3.3 创建JDBC Request2.3.4 创建结果监控2.3.5 运行结果 2.4 问题记录2.4.1 VM option UseG1GC异…

【C语言】每日一题(旋转数组)

旋转数组&#xff0c;链接奉上 目录 方法:创建额外的数组&#xff1a;整体思路&#xff1a;代码实现&#xff1a; 数组反转&#xff1a;整体思路&#xff1a;代码实现&#xff1a;小插曲&#xff1a; 方法: 创建额外的数组&#xff1a; 整体思路&#xff1a; 创建一个额外的…

oracle实现搜索不区分大小写

<if test"code ! null and code ! ">and upper(code) like upper(%${code}%) </if>关键字upper

51单片机的时钟系统

1.简介 51内置的时钟系统可以用来计时&#xff0c;与主程序分割开来&#xff0c;在计时过程中不会终端主程序&#xff0c;还可以通过开启时钟中断来执行相应的操作。 2.单片机工作方式 单片机内部有两个十六位的定时器T0和T1。每个定时器有两种工作方式选择&#xff0c;分别…

Redis-Sentinel高可用架构学习

Redis-Sentinel高可用架构 Redis主从复制过程&#xff1a; 主从同步原理 Redis Sentinel&#xff08;哨兵&#xff09;高可用集群方案&#xff1a;Redis-Sentinel是Redis官方推荐的高可用性(HA)解决方案。 当用Redis做Master-slave的高可用方案时&#xff0c;假如master宕机了…

STM32F4_照相机

目录 前言 1. BMP编码 2. JPEG编码 前言 我们所要实现的照相机&#xff0c;支持BMP图片格式的照片和JPEG图片格式的照片。 1. BMP编码 BMP文件是由文件头、位图信息头、颜色信息和图形数据四部分构成。 1. BMP文件头&#xff08;14个字节&#xff09;&#xff1a;BMP文件…

numpy矩阵画框框

在n>5(n是奇数)的nn数组中&#xff0c;用*画外方框和内接菱形。 (本笔记适合熟悉numpy的coder翻阅) 【学习的细节是欢悦的历程】 Python 官网&#xff1a;https://www.python.org/ Free&#xff1a;大咖免费“圣经”教程《 python 完全自学教程》&#xff0c;不仅仅是基础那…

c++中的继承

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、继承的概念及定义1、继承的概念2、继承的定义2.1 定义格式2.2 继承关系和访问限定符2.3 继承基类成员访问方式的变化 二、基类和派生类对象赋值转换三、继承…

【27】c++设计模式——>迭代器模式(遍历双向链表)(2)

//实现双向链表 #pragma once #include<iostream> #include<string> #include<vector> using namespace std;class Iterator; class ForwardIterator; class ReverseIterator;//链表的最小组成部分是一个节点&#xff0c;先实现一个节点 struct Node //c中st…

在Espressif-IDE中使用Wokwi仿真ESP32

陈拓 2023/10/17-2023/10/19 1. 概述 在Espressif-IDE v2.9.0版本之后可直接在IDE中使用Wokwi模拟器。 1.1 什么是 Wokwi 模拟器&#xff1f; Wokwi 是一款在线电子模拟器&#xff0c;支持模拟各种开发板、元器件和传感器&#xff0c;例如乐鑫产品 ESP32。 Wokwi 提供基于浏…

html表格标签

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title> </head> <body><!--表格table 行 tr 列 td --> <table border"1px"><tr> <!--colsp…

逻辑漏洞详解

原理&#xff1a; 没有固定的概念&#xff0c;一般都是不符合常识的情况。比如任意用户注册&#xff0c;短信炸弹&#xff0c;占用资源&#xff0c;交易支付、密码修改、密码找回、越权修改、越权查询、突破限制。 根据实际业务逻辑进行比对&#xff0c;购物的可以根据数量&a…

gulp打包vue3+jsx+less插件

最终转换结果如下 在根目录下添加gulpfile.js文件&#xff0c;package.json添加命令npm run gulp var gulp require(gulp) var babel require(gulp-babel) var less require(gulp-less) var del require(del); var spawn require(child_process).spawn;const outDir &…

【FPGA零基础学习之旅#16】嵌入式块RAM-双口ram的使用

&#x1f389;欢迎来到FPGA专栏~双口ram的使用 ☆* o(≧▽≦)o *☆嗨~我是小夏与酒&#x1f379; ✨博客主页&#xff1a;小夏与酒的博客 &#x1f388;该系列文章专栏&#xff1a;FPGA学习之旅 文章作者技术和水平有限&#xff0c;如果文中出现错误&#xff0c;希望大家能指正…

X32位汇编和X64位区别无参函数分析(一)

前言 一、X32汇编函数无参无返回分析 二、X64汇编函数无参无返回分析 总结 前言 提示&#xff1a;以下是个人学习总结&#xff1a;如有错误请大神指出来&#xff0c;只供学习参考&#xff0c;本内容使用使用VS2017开发工具&#xff1a;语言是C&#xff0c;需要一些常见的汇编指…

手机知识:安卓内存都卷到24GB了,为何iPhone还在固守8GB

目录 一、系统机制 二、生态差异 三、总结 在刚刚过去的9月&#xff0c;年货iPhone 15系列正式发布&#xff0c;标准版不出意外还是挤药膏&#xff0c;除了镜头、屏幕有些升级&#xff0c;芯片用iPhone 14 Pro系列的&#xff0c;内存只有6GB&#xff1b;即使是集钛合金机身、…

【大数据】Kafka 实战教程(一)

Kafka 实战教程&#xff08;一&#xff09; 1.Kafka 介绍1.1. 主要功能1.2. 使用场景1.3 详细介绍1.3.1 消息传输流程1.3.2 Kafka 服务器消息存储策略1.3.3 与生产者的交互1.3.4 与消费者的交互 2.Kafka 生产者3.Kafka 消费者3.1 Kafka 消费模式3.1.1 At-most-once&#xff08;…

NVIDIA NCCL 源码学习(十一)- ring allreduce

之前的章节里我们看到了nccl send/recv通信的过程&#xff0c;本节我们以ring allreduce为例看下集合通信的过程。整体执行流程和send/recv很像&#xff0c;所以对于相似的流程只做简单介绍&#xff0c;主要介绍ring allreduce自己特有内容。 单机 搜索ring 在nccl初始化的过…

51单片机仿真软件 Proteus 8 Pro 安装步骤

51单片机仿真软件 Proteus 8 Pro 安装步骤 学习 51 单片机的时候&#xff0c;如果手头没有开发板&#xff0c;可以使用仿真软件 Proteus。Proteus 可以仿真 51 单片机及周边元器件&#xff08;例&#xff1a; LED&#xff09; 的运行情况。 可以简单认为&#xff1a;Proteus …