GESP5级T1真题 [202309] 因数分解——O(sqrt(n))的时间复杂度,值得一看

描述

每个正整数都可以分解成素数的乘积,例如:6=2*3、20=22 *5

现在,给定一个正整数N,请按要求输出它的因数分解式。

输入描述

输入第一行,包含一个正整数N。约定2<=N<=10^12

输出描述

输出一行,为N的因数分解式。要求按质因数由小到大排列,乘号用星号*表示,且左右各空一格。当且仅当一个素数出现多次时,将它们合并为指数形式,用上箭头^表示,且左右不空格。

用例输入 1

复制代码
6

用例输出 1

复制代码
2 * 3

用例输入 2

复制代码
20

用例输出 2

复制代码
2^2 * 5

用例输入 3

复制代码
23

用例输出 3

复制代码
23

来源

GESP 五级

这道题就算用O(n)的方法也过不了,所以要用O(sqrt(n)),这道题的关键就是在这里。

众所周知,i*i<=n就是sqrt(n)的时间复杂度,那我们就要在其基础上写代码

ACcode

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

long long n;
bool flag=false,f2;
int main() {
	cin>>n;
	for (int i=2;i*i<=n;i++){
		if (n%i==0){
			f2=1;
			int cnt=0;
			while (n%i==0) n/=i, cnt++;//O(sqrt(n))+O(log2n)=O(sqrt(n))
			if (flag==false){
				flag=true;
			}else cout<<" * ";
			if (cnt>1){
				cout<<i<<"^"<<cnt;
			}else cout<<i;
		}
	}
	if(f2==0){
		cout<<n;
	}else if(n!=1)cout<<" * "<<n;
	return 0;
}

感谢王大佬提供思路

看了这么久,作者也写了这么久,能不能点一个赞,在收藏一下呢?最好的话在点个关注吧

谢谢啦!

相关推荐
装不满的克莱因瓶11 分钟前
掌握语义分割经典模型 FCN——从像素分类到端到端分割的奠基之作
人工智能·python·深度学习·算法·机器学习·分类·数据挖掘
学计算机的计算基15 分钟前
链表算法上篇:LeetCode 206/234/141/142/160/21 题解与易错点
java·笔记·算法·链表
大白话_NOI19 分钟前
【洛谷 P2678】 [NOIP2015 提高组] 跳石头 超详细题解
c++·算法
xwz小王子22 分钟前
ICRA 2026深度观察:全栈闭环成标配,中国具身智能势力显著崛起
大数据·人工智能·算法
孬甭_23 分钟前
深入解析归并排序:稳定高效的分治典范
算法·排序算法
DXM052131 分钟前
第14期|高阶分割模型:Transformer/SegFormer遥感应用
人工智能·python·神经网络·算法·计算机视觉·cnn·ageo
Kurisu_红莉栖1 小时前
前缀和的另外一种用法,前缀和分解
算法
88号技师1 小时前
2026年2月一区SCI-交叉传播优化算法Propagation Alongside Crossover-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
悠仁さん1 小时前
数据结构 图(代码实现篇 C语言版)
数据结构·算法·图论
chase_my_dream1 小时前
LeGO-LOAM 详细源码流程解读
c++·计算机视觉·自动驾驶