首页 > 解决方案 > 如何消除素数分解输出中显示的额外星号?

问题描述

以下代码从用户输入一个整数 (n) 并输出 n 的素数分解。我需要有以下输出(例如),但无法达到:

输入:98

输出:2*7^2

实际的错误输出,有一个额外的“*”是:

2*7^2*
     ^

也许还有另一种使用函数的解决方案,我不知道。

#include <iostream>
#include <cmath>
using namespace std;

int main()
{
    int n, countA = 0, countB = 0;
    cin>>n;
    while(n % 2 == 0)
    {
        n /= 2;
        countA++;
    }
    if(countA == 1)
        cout<<2<<"*";
    else if(countA != 0)
        cout<<2<<"^"<<countA;
    for(int i = 3; i <= sqrt(n); i = i + 2)
    {
        while(n % i == 0)
        {
            n /= i;
            countB++;
        }
        if(countB == 1)
            cout<<i<<"*";
        else if(countB != 0)
        cout<<i<<"^"<<countB<<"*";
    }
    if(n > 2)
        cout<<n;
    return 0;
}

标签: c++coutprime-factoring

解决方案


而不是无条件地打印它:

cout<<i<<"^"<<countB<<"*";

你可以测试它是否是最后一个数字。示例(适用于任何需要的地方):

for(int i = 3, end = sqrt(n); i <= end; i = i + 2) {
    // ...
    cout << i << '^' << countB;
    if(i + 2 <= end) cout << '*';

推荐阅读