蓝桥 算法训练 粘木棍(C++)

2024-02-23 15:12
文章标签 算法 c++ 训练 蓝桥 木棍

本文主要是介绍蓝桥 算法训练 粘木棍(C++),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题描述

  有N根木棍,需要将其粘贴成M个长木棍,使得最长的和最短的的差距最小。

输入格式

  第一行两个整数N,M。
  一行N个整数,表示木棍的长度。

输出格式

  一行一个整数,表示最小的差距

样例输入

3 2
10 20 40

样例输出

10

数据规模和约定

  N, M<=7

题目链接:“蓝桥杯”练习系统


思路一:

此题给出的知识标签是搜索,那就想dfs,不断尝试两个数据合并一个数据,当到达m个数据时,寻找此时最大最小值,做差,然后回溯,换两个数据合并,到达m个数,再回溯…… 直到所有情况合并完,对于这个题来说,n,m都小于等于7,这样做完全没问题,但是时间复杂度比较大,盲目搜索,有一些不必要的合并,这种方法不太推荐,写一下代码,交上也可以过。

#include<iostream>
using namespace std;
int n,m;
int a[10];
int sum=0x3f3f;
void dfs(int k) {if(k==m) {int maxx=0;int minx=0x3f3f;for(int i=0; i<m; i++) {minx=min(minx,a[i]);maxx=max(maxx,a[i]);}sum=min(maxx-minx,sum);return;}for(int i=0; i<k; i++) {for(int j=i+1; j<k; j++) {a[i]+=a[j];int tmp=a[j];a[j]=a[k-1];a[k-1]=tmp;dfs(k-1);tmp=a[j];a[j]=a[k-1];a[k-1]=tmp;a[i]-=a[j];}}
}
int main() {cin>>n>>m;for(int i=0; i<n; i++) {cin>>a[i];}dfs(n);cout<<sum<<endl;return 0;
}


思路二:

思路二就有点贪心的思想了,我们可以简化为一个模型,有n个数,m个箱子,不断往里面放数,每放一个数就要遍历一遍寻找最小值的箱子,然后把数放进去,直到放完为止,越往后的数,数越小(前提由大到小排好序),这样也就达到了我们寻找最小差值的目的。首先我们先初始化m个箱子的初始值,我们要选n个数中前m大的数,作为m个箱子的初始值,为什么选前m大的值,因为我们要求最小差值,先放完最大值,剩下小的,不断往里面补,使得减小差值的目的,比如样例,10 20 40,先选,20,40作为箱子,遍历一遍寻找最小值20,把10放进去,更新为30,数都放完了,此时最小差值10。如果前m小的数作为箱子,10,20,寻找最小值10,把40放进去,更新为50,最小差值为20。这样保证了每次更新都是有用的更新,大大降低了时间复杂度。话不多说,上代码。

#include<iostream>
#include<algorithm>
using namespace std;
int n,m;
int a[10],b[10];
int cmd(int A,int B){return A>B;
}
int main(){cin>>n>>m;for(int i=0;i<n;i++){cin>>a[i];}sort(a,a+n,cmd);//由大到小排序for(int i=m;i<n;i++){//遍历除去前m大的数,往里面添加int index=0;int minx=0x3f3f3f;for(int j=0;j<m;j++){//选取前m大的数相当于箱子,哪个数小,就往里放if(a[j]<minx){//寻找此时前m大的数最小值index=j;//记录下标minx=a[j];//更新值}}a[index]+=a[i];//找到最小的值(箱子),把此时未放进去的数,加上}int maxx=0;int minx=0x3f3f3f;for(int i=0;i<m;i++){//寻找此时最大最小值,做差maxx=max(maxx,a[i]);minx=min(minx,a[i]);}cout<<maxx-minx<<endl;return 0;
}

以上为本人刷题思路总结,此题比较简单,属于小白签到题,愿与大家共同进步。

这篇关于蓝桥 算法训练 粘木棍(C++)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/739039

相关文章

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为

C++一个数组赋值给另一个数组方式

《C++一个数组赋值给另一个数组方式》文章介绍了三种在C++中将一个数组赋值给另一个数组的方法:使用循环逐个元素赋值、使用标准库函数std::copy或std::memcpy以及使用标准库容器,每种方... 目录C++一个数组赋值给另一个数组循环遍历赋值使用标准库中的函数 std::copy 或 std::

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没

c++中std::placeholders的使用方法

《c++中std::placeholders的使用方法》std::placeholders是C++标准库中的一个工具,用于在函数对象绑定时创建占位符,本文就来详细的介绍一下,具有一定的参考价值,感兴... 目录1. 基本概念2. 使用场景3. 示例示例 1:部分参数绑定示例 2:参数重排序4. 注意事项5.

使用C++将处理后的信号保存为PNG和TIFF格式

《使用C++将处理后的信号保存为PNG和TIFF格式》在信号处理领域,我们常常需要将处理结果以图像的形式保存下来,方便后续分析和展示,C++提供了多种库来处理图像数据,本文将介绍如何使用stb_ima... 目录1. PNG格式保存使用stb_imagephp_write库1.1 安装和包含库1.2 代码解

C++实现封装的顺序表的操作与实践

《C++实现封装的顺序表的操作与实践》在程序设计中,顺序表是一种常见的线性数据结构,通常用于存储具有固定顺序的元素,与链表不同,顺序表中的元素是连续存储的,因此访问速度较快,但插入和删除操作的效率可能... 目录一、顺序表的基本概念二、顺序表类的设计1. 顺序表类的成员变量2. 构造函数和析构函数三、顺序表