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

网站定制报价推荐企业门户网站建设

网站定制报价,推荐企业门户网站建设,比较好的平面设计网站,拼客多网站多少钱可以做2023每日刷题(五) Leetcode—2530.执行K次操作后的最大分数 向上取整思想 参考了这篇文章 有人肯定会问,这个向上取整为什么是这样来的。接下来我简单讲解一下。 数学式: x y 数学式:\frac{x}{y} 数学式&#xff1a…

2023每日刷题(五)

Leetcode—2530.执行K次操作后的最大分数

在这里插入图片描述

向上取整思想

参考了这篇文章
在这里插入图片描述
有人肯定会问,这个向上取整为什么是这样来的。接下来我简单讲解一下。

数学式: x y 数学式:\frac{x}{y} 数学式:yx有以下两种情况

  • x能整除y,则 x y \frac{x}{y} yx就是向上取整和向下取整结果一致的情况,不需要额外转换。也就是说 x y \frac{x}{y} yx的向上取整和向下取整都是它本身,例如 6 3 = 2 \frac{6}{3}=2 36=2 6 3 \frac{6}{3} 36向下取整和向上取整结果都一样,即为2
  • x不能整除y,则 x y \frac{x}{y} yx是向下取整结果,不符合我们的需求。例如 5 2 = 2 \frac{5}{2}=2 25=2,但是我们需要它的向上取整的值,就不能直接用/。

解释一下 ( x + y − 1 ) / y (x + y - 1) / y (x+y1)/y

  • 如果x能整除y,那么 ( x + y − 1 ) / y (x + y - 1) / y (x+y1)/y的结果就等价于 x / y x / y x/y,例如 6 3 = 2 \frac{6}{3}=2 36=2
  • 如果x不能整除y,那么 ( x + y − 1 ) / y (x + y - 1) / y (x+y1)/y结果就是向上取整的值。例如 x = 5 , y = 2 x=5,y=2 x=5,y=2,则 ( 5 + 2 − 1 ) / 2 = 3 (5 + 2 - 1) / 2 = 3 (5+21)/2=3,即为 5 2 \frac{5}{2} 25向上取整的值。

你也可以这么理解,

  • 若x能整除y,例如x=2y,所以向上整除为2
  • 若x不能整除y,例如x=2y+1,也可以是 [ 2 y + 1 , 3 y ) \left[2y+1, 3y\right) [2y+1,3y),所以 ( x + y − 1 ) / y = ( 2 y + 1 + y − 1 ) = 3 (x + y - 1) / y = (2y + 1 + y - 1) = 3 (x+y1)/y=(2y+1+y1)=3

直接法实现代码

void max(int *nums, int numsSize, int *e) {int i = 0;int max = nums[0];int cnt = 0;for(i = 1; i < numsSize; i++) {if(max < nums[i]) {max = nums[i];cnt = i;}}*e = cnt;
}long long maxKelements(int* nums, int numsSize, int k){int i = 0;long long ans = 0;int cur = 0;for(; i < k; i++) {max(nums, numsSize, &cur);ans += nums[cur];nums[cur] = (nums[cur] + 2) / 3;}return ans;
}

测试结果

在这里插入图片描述
因为我的时间复杂度太大了,即 O ( k n ) O(kn) O(kn),主要是也没要求时间复杂度啊。。。接下来用最大堆的方法做,也就是大根堆

最大堆实现代码

void swap(int *a, int *b) {int tmp = *a;*a = *b;*b = tmp;
}void downAdjustHeap(int* heap, int low, int high) {// 相当于双亲为i,左孩子为2*i+1,右孩子为2*i+2,因为这里数组从下标0开始int i = low, j = i * 2 + 1;while(j <= high) {if(j + 1 <= high && heap[j + 1] > heap[j]) {j = j + 1;}if(heap[j] > heap[i]) {swap(&heap[j], &heap[i]);i = j;j = j * 2 + 1;} else {break;}}
}void createHeap(int* arr, int n) {// 建立大顶堆int i;for(i = n / 2 - 1; i >= 0; i--) {downAdjustHeap(arr, i, n - 1);}
}long long maxKelements(int* nums, int numsSize, int k){// 建立大顶堆,即最大堆createHeap(nums, numsSize);long long ans = 0;int i;for(i = 0; i < k; i++) {ans += nums[0];// 向上取整nums[0] = (nums[0] + 2) / 3;downAdjustHeap(nums, 0, numsSize - 1);}return ans;
}

在这里插入图片描述

测试结果

在这里插入图片描述
之后我会持续更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗感谢支持!

http://www.yayakq.cn/news/438758/

相关文章:

  • 建设企业网站的网站怎么做cp备案号
  • 网站建设推销话术案例网上怎么免费推广
  • php编程语言seo营销是指
  • 做预约的网站木疙瘩h5官网
  • 网站开发 ssh 菜鸟搜索栏在wordpress菜单上位置
  • 网站空间租用价格北京想象力网站建设
  • 对外贸易网站有哪些步骤点页面设计
  • 企业平台网站建设做网站时怎么让边框细一点
  • 泰州企业网站建设公司诚聘php网站开发师
  • 做网站 多页面网址怎么弄做景观设施的网站
  • 做网站需要哪些人手wordpress收费下载插件
  • 有关网站开发的文献或论文北京网站开发费用
  • 做自己的优惠券网站学编程怎么入门
  • 徐州做网站推广方法有哪些技巧
  • 一般用网站服务器简易广州网站建设
  • 北京鑫创网站建设中小型网站建设精英
  • 柯桥网站建设群晖wordpress远程安装
  • 网站的建设与管理的心得体会wordpress文章采集助手
  • 装饰公司网站如何做推广贵州建设厅网站二建
  • 网站如何接广告海兴县做网站
  • 天津开发区网站网站制作要学哪些
  • 手机上有那种网站吗宝坻区建设路小学网站
  • 网站建设一般考虑哪些因素广州哪里有外贸网站
  • 免费做网站网站的软件宁波城乡住房建设局网站
  • wordpress生活插件seo优化排名价格
  • 自己做视频类网站用哪个cms济南建站模板
  • 基本信息型营销网站有哪些昌乐营销型网站建设
  • php网站开发说明文档济南做网络安全的公司
  • 有什么网站可以做运动鞋软件的开发定制
  • 广州手机网站建设wordpress页面瀑布流