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

题目

分析

上来一看,三个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);	
}
}
相关推荐
立志成为大牛的小牛10 分钟前
数据结构——四十、折半查找(王道408)
数据结构·学习·程序人生·考研·算法
王哈哈^_^24 分钟前
【完整源码+数据集】蓝莓数据集,yolo11蓝莓成熟度检测数据集 3023 张,蓝莓成熟度数据集,目标检测蓝莓识别算法系统实战教程
人工智能·算法·yolo·目标检测·计算机视觉·ai·视觉检测
王哈哈^_^37 分钟前
【完整源码+数据集】高空作业数据集,yolo高空作业检测数据集 2076 张,人员高空作业数据集,目标检测高空作业识别系统实战教程
人工智能·算法·yolo·目标检测·计算机视觉·目标跟踪·视觉检测
一条数据库44 分钟前
猫狗识别数据集:34,441张高质量标注图像,深度学习二分类任务训练数据集,计算机视觉算法研发,CNN模型训练,图像识别分类,机器学习实践项目完整数据资
深度学习·算法·机器学习
bloxd yzh1 小时前
图论基础概念
算法
小白程序员成长日记1 小时前
2025.11.09 力扣每日一题
算法·leetcode·职场和发展
hansang_IR1 小时前
【题解】洛谷 P1477 [NOI2008] 假面舞会 [思维 + 图论]
c++·算法·图论·思维
天选之女wow1 小时前
【代码随想录算法训练营——Day59】图论——47.参加科学大会、94.城市间货物运输I
算法·图论
CoovallyAIHub1 小时前
1.2MB超轻量模型实现草莓苗精准分级检测与定位,准确率超96%
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
终结AI偏见!Sony AI发布Nature论文与FHIBE数据集,重塑公平性评估基准
深度学习·算法·计算机视觉