LeetCode——1954. 收集足够苹果的最小花园周长

通过万岁!!!

  • 题目:这个题目比较复杂,就是给你一个坐标轴,然后让你以0,0为中心选择一个边长为整数的正方形,使得正方形中所有点坐标的绝对值之和要大于给定的neededApples。但是我们需要输出的是这个正方形的周长。
  • 基础思路:我们首先把思路定在第一象限,然后坐标轴x的长度8,则得到最后要的周长。我们以x的长度为2进行举例,并且我们只考虑周长上的点,那么我们第一象限需要考虑的点就是(1,2)、(2,2)、(2,1)、(2,0)。需要注意的是(0,2)和(2,0)我们只需要考虑一个就好了。然后我们沿着第一象限正方形的对角线(y=x)对正方形分成两部分,然后只考虑垂直于x轴的这条边,上面的点包括(2,2)、(2,1)、(2,0),我们发现在第一象限中,(2,2)和(2,0)我们只需要计算一次,但是(2,1)这种情况我们需要计算两次。也就是说,在第一象限中,一条边上的点,头尾我们只需要计算一次就好了,但是中间的我们需要计算两次。以垂直于x轴的边来说,正方形的变成为i,则(i,0)和(i,i)我们只需要计算一次,(i,k)则需要计算两次。然后最后将这个结果4,则得到边长为2*i时正方形边上的苹果个数。剩下的就是只需要把上次的加上,然后看一下是不是大于neededApples就好了。上面的代码就得到的第一版,但是这个代码超时了。写完以后就发现,其实可以优化的。
    示意图
  • 优化思路:其实里面的for循环我们可以优化的,(i,k)的点我们需要计算2次,一共由i-1个点。那么针对x坐标来说有i*(i-1)2个苹果,对于y坐标来说,我们有(1+2+…+(i-1))2个苹果,然后再加上首位两个i2+i,然后再4个象限,最终换算出来的结果是12ii。所以while中的代码最终可以优化为i++以后,sum+=12ii。
  • 技巧:数学

java代码——基础思路

class Solution {public long minimumPerimeter(long neededApples) {long i = 1, sum = 12;while (sum < neededApples) {i++;sum += (i + i) * 4;// (i,i)这个点sum += i * 4;// (i,0)这个点for (int k = 1; k < i; k++) {sum += (i + k) * 2 * 4;// 中间的(i,k)的点}}return i * 8;}
}

java代码——优化思路

class Solution {public long minimumPerimeter(long neededApples) {long i = 1, sum = 12;while (sum < neededApples) {i++;sum += 12 * i * i;}return i * 8;}
}
  • 总结:题目不是特别难,但是要发现这里面的规律,画画图其实就出来了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/298276.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenHarmony之内核层解析~

OpenHarmony简介 技术架构 OpenHarmony整体遵从分层设计&#xff0c;从下向上依次为&#xff1a;内核层、系统服务层、框架层和应用层。系统功能按照“系统 > 子系统 > 组件”逐级展开&#xff0c;在多设备部署场景下&#xff0c;支持根据实际需求裁剪某些非必要的组件…

C++ 比 C语言增加的新特性 2

1.C新增了带默认值参数的函数 1.1 格式 格式&#xff1a;返回值 函数名&#xff08;参数1初始值1&#xff0c;..........&#xff09;{} 例如&#xff1a;void function&#xff08;int a10&#xff09;{} 调用&#xff1a;不需要更改参数的值&#xff1a;function&#x…

AI日报:2024年人工智能对各行业初创企业的影响

欢迎订阅专栏 《AI日报》 获取人工智能邻域最新资讯 文章目录 2024年人工智能对初创企业的影响具体行业医疗金融服务运输与物流等 新趋势 2024年人工智能对初创企业的影响 2023年见证了人工智能在各个行业的快速采用和创新。随着我们步入2024年&#xff0c;人工智能初创公司正…

双向可控硅触发电路图大全

双向可控硅触发电路图一&#xff1a; 为了提高效率&#xff0c;使触发脉冲与交流电压同步&#xff0c;要求每隔半个交流电的周期输出一个触发脉冲&#xff0c;且触发脉冲电压应大于4V&#xff0c;脉冲宽度应大于20us.图中BT为变压器&#xff0c;TPL521-2为光电耦合器&#xff…

2023RT-Thread开发者大会

参加了一次RT-Thread的开发者大会&#xff0c;相当有意思&#xff0c;虽然一天奔波挺累&#xff0c;但睡了半天之后简单剪了下22号的视频&#xff0c;也就有时间写自己的参会笔记了。 与openEuler社区不同&#xff0c;RT-Thread社区更专注于嵌入式&#xff0c;与硬件厂商结合较…

WorkPlus一站式协同解决方案,助力企业降本增效

在企业数字化转型的过程中&#xff0c;很多企业都会遇到一个共同问题&#xff1a;重复建设基础功能&#xff0c;耗费大量时间和资源。为解决这一难题&#xff0c;WorkPlus已经将一些通用、基础且有技术门槛的功能进行了集成与开发&#xff0c;如IM&#xff08;即时通讯&#xf…

渗透测试——1.1初认识kali

一、kali的下载 官方地址&#xff1a;www.kali.org 下载后压缩就可用vmware打开即可&#xff08;初始账号和密码都是kali&#xff09; 二、三种网络配置 1、桥接模式&#xff1a;将虚拟机看成局域网中的独立主机 2、NAT模式&#xff1a;将物理机当做路由器&#xff08;rout…

操作无法完成(错误 0x000006ba),Windows 11 PDF打印机无法使用解决办法

操作无法完成(错误 0x000006ba)&#xff0c;Windows 11 PDF打印机无法使用解决办法 解决方式一 先重启一次电脑&#xff0c;看看是否可以解决问题。 解决方式二 重新启动 Printer Spooler 服务

doris基本操作,02-创建复合分区表

创建复合分区表 create table table2 (event_day DATE,siteid int defautl 10,citycode smallint,username varchar(32) defautl ,pv bigint sum default 0 )aggregate key (event_day, siteid, citycode, username) -- 按照event_day做range分区 -- paritition by range(even…

继承易错总结

1.继承会将所有的成员继承下来&#xff0c;但是继承方式限定的是继承下来成员的可见类型(如果是private继承&#xff0c;那么他不论哪里都是不可见的&#xff1b;如果是protected继承在类中是可见的&#xff0c;在类外是不可见的&#xff1b;如果是public继承&#xff0c;在任何…

C++ Qt开发:Charts折线图绑定事件

Qt 是一个跨平台C图形界面开发库&#xff0c;利用Qt可以快速开发跨平台窗体应用程序&#xff0c;在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置&#xff0c;实现图形化开发极大的方便了开发效率&#xff0c;本章将重点介绍QCharts折线图的常用方法及灵活运用。 在上一…

ZLMediaKit中的RingBuffer

前面的文章讲到ZLMediaKit转流&#xff0c;提到过RingBuffer&#xff0c;它是比较核心的数据结构。这篇文章就来讲讲RingBuffer的用法。 RingBuffer的类体系 RingBuffer是由多个类组成&#xff0c;分为两大功能&#xff1a;存储和数据分发。 存储功能由类RingStorage实现&…