当前位置: 首页 > news >正文

算法设计与分析(乘船问题

目录

  • 题目描述
  • 解题思路
  • 代码实现
  • 小结:

题目描述

给定一批轮船,每艘轮船的最大载重量均为M,每艘船最多只允许装两个人,旅客总人数最多为50人。每个旅客的体重不同。现要求设计算法求出装走所有旅客所需轮船的最少数量。

输入格式

第一行输入为每艘船的最大载重量M和旅客总人数num。
第二行输入是每个旅客的体重(整数)。

输出格式

输出所需最少租船数量。

解题思路

本题可以使用贪心算法来解决。贪心算法的思想是在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望导致结果是全局最好或最优的算法。

排序:首先将所有旅客的体重进行从小到大排序。这样可以尽可能地将最重的旅客与最轻的旅客配对,从而更有效地利用每艘船的载重能力。

双指针:使用两个指针p_l和p_r,分别指向体重数组的开始和结束。这两个指针模拟了从两端向中间配对的过程。

遍历:在p_l小于等于p_r的条件下进行循环。每次循环检查当前最轻的旅客和最重的旅客的体重之和是否小于等于船的最大载重量M。

如果是,说明这两个旅客可以装在同一艘船上,将p_l向右移动一位,p_r向左移动一位。
如果不是,说明最重的旅客无法与当前最轻的旅客配对,只能单独装一艘船(或尝试与下一个较轻的旅客配对),将p_r向左移动一位。
计数:每成功装载一对旅客(或单独装载一个旅客),就增加所需的船只数量result。

输出结果:循环结束后,输出result作为答案。

代码实现

下面是该算法的C++实现:

#include<iostream>  
#include<algorithm>  using namespace std;  #define MAXSIZE 50  int main() {  // 输入数据   int w[MAXSIZE], num, M;  cin >> M >> num;  for (int i = 0; i < num; i++){  cin >> w[i];  }  // 贪心算法  sort(w, w + num);	// 从小到大排序   int p_l = 0;  int p_r = num - 1;  int result = 0;  while (p_l <= p_r){  if ((w[p_l] + w[p_r]) <= M){  p_l++;p_r--;  }  else{  p_r--;  }  }  cout << result << endl;  return 0;  
}  

小结:

关注我给大家分享更多有趣的知识,以下是个人公众号,提供 ||竞赛资料|| ||课程资料||
添加我的公众号即可:


http://www.mrgr.cn/news/21523.html

相关文章:

  • 结构化开发方法的三种基本控制结构
  • SAP学习笔记 - 开发01 - BAPI是什么?通过界面和ABAP代码来调用BAPI
  • 多机编队—(2)Ubuntu安装Eigen OSQP OSQP-EIGEN求解器
  • 域取证的日志分析
  • QString如何格式化字符串
  • python学习
  • Mysql梳理1——数据库概述(下)
  • 优化算法与正则化
  • WPF入门到跪下 第十三章 3D绘图 - 3D绘图基础
  • Vue 中实现视频播放的艺术
  • 新手炒股,用Python股票接口程序化交易股票需要注意什么
  • Chapter 10 Stability and Frequency Compensation
  • DHCP服务
  • 【Linux】环境变量
  • 828华为云征文|华为云Flexus X实例docker部署最新gitlab社区版,搭建自己的私人代码仓库
  • 【Hot100】LeetCode—394. 字符串解码
  • vsCode 自动发布文件到服务器文件
  • 【 html+css 绚丽Loading 】000042 乾坤四象盘
  • 诺瓦星云校招嵌入式面试题及参考答案(100+面试题、10万字长文)
  • 【MATLAB】模拟退火算法