C++分解质因数

这段C++代码实现了一个整数分解质因数的功能。程序接收一个整数N作为输入,输出其质因数分解结果。例如输入24,输出"24=222*3"。算法采用循环除法,从2开始逐个尝试除数,若能整除则记录该因数并继续分解,直到N变为1。对于特殊值1会直接输出"1=1"。程序使用isFirst标志来正确处理因数间的乘号连接。

输入

24

输出

24=2*2*2*3

cpp 复制代码
#include <iostream>
using namespace std;
int main(){
    int N;
    cin>>N; 
    cout<<N<<"=";
    if(N==1){
        cout<<"1"<<endl;
        return 0;
    } 
    bool isFirst=true;
    for(int i=2;i*i<=N;){
        while(N%i==0){
            if(isFirst){
                cout<<i;
                isFirst=false;
            }else{
                cout<<"*"<<i;
            }
            N/=i;
        }
        i++;
    }
    if(N>1){
        if(isFirst){
            cout<<N;
        }else{
            cout<<"*"<<N;
        }
    }
    return 0;
}
 
相关推荐
寒秋花开曾相惜1 小时前
(学习笔记)第四章 处理器体系结构
linux·网络·数据结构·笔记·学习
故事和你912 小时前
洛谷-数据结构1-1-线性表1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论
脱氧核糖核酸__2 小时前
LeetCode热题100——53.最大子数组和(题解+答案+要点)
数据结构·c++·算法·leetcode
脱氧核糖核酸__2 小时前
LeetCode 热题100——42.接雨水(题目+题解+答案)
数据结构·c++·算法·leetcode
王老师青少年编程3 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:数列分段 Section I
c++·算法·编程·贪心·csp·信奥赛·线性扫描贪心
王老师青少年编程3 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:分糖果
c++·算法·贪心算法·csp·信奥赛·线性扫描贪心·分糖果
_日拱一卒3 小时前
LeetCode:2两数相加
算法·leetcode·职场和发展
py有趣3 小时前
力扣热门100题之零钱兑换
算法·leetcode
董董灿是个攻城狮3 小时前
Opus 4.7 来了,我并不建议你升级
算法
自我意识的多元宇宙3 小时前
二叉树遍历方式代码解读(2迭代)
数据结构