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

题目

分析

上来一看,三个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);	
}
}
相关推荐
alphaTao13 小时前
LeetCode 每日一题 2025/12/15-2025/12/21
算法·leetcode
写写闲篇儿16 小时前
下一个更大元素(一)
数据结构·算法
MobotStone17 小时前
从金鱼记忆到过目不忘:Transformer 如何让AI真正理解一句话?
算法
炽烈小老头18 小时前
【每天学习一点算法 2025/12/19】二叉树的层序遍历
数据结构·学习·算法
Xの哲學19 小时前
Linux grep命令:文本搜索的艺术与科学
linux·服务器·算法·架构·边缘计算
soft200152519 小时前
MySQL Buffer Pool深度解析:LRU算法的完美与缺陷
数据库·mysql·算法
WBluuue19 小时前
AtCoder Beginner Contest 436(ABCDEF)
c++·算法
fie888920 小时前
广义 S 变换(GST)地震信号时频谱
算法
json{shen:"jing"}20 小时前
1-C语言的数据类型
c语言·c++·算法
im_AMBER21 小时前
数据结构 13 图 | 哈希表 | 树
数据结构·笔记·学习·算法·散列表