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

备战蓝桥杯---基础算法刷题1

最近在忙学校官网上的题,就借此记录分享一下有价值的题:

1.注意枚举角度

如果我们就对于不同的k常规的枚举,复杂度直接炸了。

于是我们考虑换一个角度,我们不妨从1开始枚举因子,我们记录下他的倍数的个数sum个,

这样子我们就保证了最大gcd至少为他的个数有sum个。

然后我们从k=1开始,倒着输出即可。(这里提供了一种求gcd的新的思路,很有意思)

这里提一下复杂度的问题,外层为n,里面为n/i;

对于\sum_{i=1}^{i=n}1/i学过高数的都知道他约为inn,因此复杂度为nlogn就可以了。

下面是AC代码:

#include<bits/stdc++.h>
using namespace std;
int a[1000010],b[1000010],n,x,max1=-1000000,ans[1005];
int main(){cin>>n;for(int i=1;i<=n;i++){scanf("%d",&x);a[x]++;max1=max(max1,x);}for(int i=1;i<=max1;i++){for(int j=i;j<=max1;j+=i){if(j%i==0) b[i]+=a[j];}}int k=1;for(int j=max1;j>=1;j--){if(k>n) break;if(b[j]>=k){k++;printf("%d\n",j);j++;continue;}}
}

2.注意等效:

首先,对于把n-1个数+1,其实就是等效于指定一个数-1.

然后我们考虑相等时的数是多少。

在这里我们应该还记得带权中位数的概念(前面有讲),我们相当于让这些权1的点走到某一点处总距离min,我们只要求中位数即可。

3.水题

我们把划分两个序列区间看成向两个容器中按顺序添加值。

显然,分值加不加就看最后一个数,我们假设一个容器1最后为a,另一个容器2最后为b.(a>=b)

此时要加进来的为c,如果c>=a,那么加在b后肯定更优。

如果c<=b,那么加在b后肯定更优。

若b<c<a,那么放在a后更优,请看下面的分析:

http://www.lryc.cn/news/305033.html

相关文章:

  • 探索 Flutter 中的动画:使用 flutter_animate
  • 装机容量对光伏发电量的影响有多大?如何通过装机容量计算发电量?
  • 软考37-上午题-【数据库】-数据模型、数据库的三级模式和二级映像
  • 06 分频器设计
  • 力扣hot100题解(python版7-9题)
  • ECMAScript 6+ 新特性 ( 四 ) 迭代器 与 生成器
  • 【MySQL】事务的一致性究竟怎么理解?
  • 证件照(兼容H5,APP,小程序)
  • pytorch-textregression,中文文本回归实践,支持多值输出
  • go语言学而思【持续更新】
  • LVS-NAT之VMNET环境搭建
  • [TCP] TCP/IP 基础知识词典(2)
  • 【牛牛送书 | 第四期】《高效使用Redis:一书学透数据存储与高可用集群》带你快速学习使用Redis
  • Threejs 实现3D影像地图,Json地图,地图下钻
  • 根据Excel创建管道系统及材质
  • 第八篇【传奇开心果系列】python的文本和语音相互转换库技术点案例示例:Google Text-to-Speech虚拟现实(VR)沉浸式体验经典案例
  • ubuntu使用LLVM官方发布的tar.xz来安装Clang编译器
  • Windows 远程控制 Mac 电脑怎么操作
  • c# HttpCookie操作,建立cookie工具类
  • 【这个词(Sequence-to-Sequence)在深度学习中怎么解释,有什么作用?】
  • 挑战30天学完Python:Day16 日期时间
  • Web3之光:揭秘数字创新的未来
  • Stable Diffusio——采样方法使用与原理详解
  • 小米14 ULTRA:重新定义手机摄影的新篇章
  • 【leetcode热题】路径总和 II
  • ChatGPT在数据处理中的应用
  • 微服务-Alibaba微服务nacos实战
  • Linux Driver | 设备树开发之初识设备树
  • 2月24日(周六)比赛前瞻:曼联 VS 富勒姆、拜仁 VS 莱比锡
  • React18源码: task任务调度和时间分片