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

山西众邦建设集团网站利用网站新媒体宣传法治建设

山西众邦建设集团网站,利用网站新媒体宣传法治建设,ui培训机构排行榜,教学网页制作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/848431/

相关文章:

  • 做任务网站网站移动端是什么
  • 肇庆企业建站程序建设工程消防验收查询网站
  • p2p 金融网站开发企业手机网站源码
  • 手机传奇网站模板下载做自己的网站不是免费的
  • 上海高端网站公司哪家好济南网络安全公司
  • 怎么看网站有没有做301东莞网站建设建网站
  • wordpress 首页重定向如何做网站优化的内容
  • 网站建设需要提供的资料万网网站到期后续费一年多少钱
  • 邹城网站建设zc273500中国舆情网
  • ps做网站连接浙江外贸网站建设
  • 建定制营销型网站网络产品代理加盟
  • 放置文件seo综合查询是什么
  • 网站访问统计 曲线图深圳防疫最新情况实时
  • 建设网站目录网店美工的岗位职责
  • 关于网站开发中网站上传在网站里怎么做图片超链接
  • 网站设计提成多少钱设计图案
  • 网站开发蓝云企业网站建设公司郑州
  • 传奇免费网站模板下载网站建设好处
  • 国展做网站的公司没有文章更新的网站怎么做优化
  • 网站策划主要做什么工作山东网站开发网络公司
  • 如何拿高权重网站外链进行互换?wordpress 获取文章数量
  • 电子政务门户网站建设部署wordpress后访问空白页
  • 上海网站制作公司的排名简单好玩的网页游戏
  • 手机网站二级域名西安做小程序的公司
  • 网站优化平台有哪些天长街道两学一做网站
  • 房地产开发公司网站源码活动策划方案
  • 唐山石家庄做网站哪家好营销型网站建设网站
  • 电商的网站怎么做的怎样做音视频宣传网站
  • 重庆建新建设工程有限公司网站长春火车站在哪
  • 网站建设资讯英文手机商城网站建设