蓝桥杯每日一题----货物摆放

题目

分析

上来一看,三个for循环,从1到n,寻找满足lw h=n的个数,但是这样根本跑不出来答案,n太大了,1e15的级别,O(n)的时间复杂度都不行,更何况是O(n^3)。

尝试降低时间复杂度很难,可以尝试降低数据规模。

插入理论:影响代码运行时间的两个因素算法时间复杂度和数据规模。

我们可以观察一下,满足lwh=n的l,w和h有什么特点。他们肯定是n的因子,那么我们只需要遍历n的因子就可以了。怎么求n的因子呢?一个for循环遍历即可,时间复杂度是O(sqrt(n)),满足要求。

解题

第一步:

求n的因子的代码如下,

java 复制代码
long n = 2021041820210418l;
	Set<Long> set = new HashSet<Long>();
	for(long i = 1;i <= n / i;i++) {
		if(n%i==0) {
			set.add(i);
			set.add((n/i));
		}
	}

因为找到一个小于sqrt(n)的因子i,必然也能根据i找到大于sqrt(n)的另一个因子,即n/i。

第二步:

遍历n的因子

java 复制代码
long ans = 0;
	for(Long a:set)
		for(Long b:set)
			for(Long c:set)
				if(a*b*c==n) ans++;

第三步:

输出答案

java 复制代码
System.out.println(ans);	

完整代码:

java 复制代码
import java.util.HashSet;
import java.util.Set;

public class 货物摆放 {
public static void main(String[] args) {
	long n = 2021041820210418l;//2430
	Set<Long> set = new HashSet<Long>();
	for(long i = 1;i <= n / i;i++) {
		if(n%i==0) {
			set.add(i);
			set.add((n/i));
		}
	}
	long ans = 0;
	for(Long a:set)
		for(Long b:set)
			for(Long c:set)
				if(a*b*c==n) ans++;
	System.out.println(ans);	
}
}
相关推荐
happygrilclh13 小时前
高压高频电源的pid算法
算法
格林威13 小时前
Baumer相机铸件气孔与缩松识别:提升铸造良品率的 6 个核心算法,附 OpenCV+Halcon 实战代码!
人工智能·opencv·算法·安全·计算机视觉·堡盟相机·baumer相机
葫三生13 小时前
存在之思:三生原理与现象学对话可能?
数据库·人工智能·神经网络·算法·区块链
Evand J13 小时前
【MATLAB例程】无人机三维路径规划|A*,RRT(快速随机树算法), APF(人工势场法)算法对比|可自定义起终点、障碍物坐标。附下载链接
算法·matlab·无人机·astar·路径规划·rrt·apf
少许极端14 小时前
算法奇妙屋(二十七)-全排列与子集问题
算法·剪枝·回溯·递归
sali-tec14 小时前
C# 基于OpenCv的视觉工作流-章20-仿射变换
图像处理·人工智能·opencv·算法·计算机视觉
u01092727114 小时前
实时数据流处理
开发语言·c++·算法
独自破碎E14 小时前
【滑动窗口+计数】LCR015找到字符串中所有字母异位词
数据结构·算法
Trouvaille ~14 小时前
【Linux】线程同步与互斥(一):线程互斥原理与mutex详解
linux·运维·服务器·c++·算法·线程·互斥锁
2501_9403152614 小时前
leetcode统计一致字符串的数目(哈希表)
算法·哈希算法·散列表