11653번: 소인수분해

문제접근🤔


놓쳤던 부분😅


#include <iostream>
#include <vector>
#include <cmath>

int main() {
    int N;
    std::cin >> N;

    std::vector<int> factors;
    for (int i = 2; i <= sqrt(N); i++) {
        while (N % i == 0) {
            factors.push_back(i);
            N /= i;
        }
    }
    if (N > 1) {
        factors.push_back(N);
    }

    for (int factor : factors) {
        std::cout << factor << "\\n";
    }

    return 0;
}

코드😁


2024 KB

32 ms

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int main(void)
{
	int n;
	vector<int> answer;

	ios_base::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);

	cin >> n;
	if (n != 1)
	{
		while (n > 1)
		{
			for (int i = 2; i <= n; i++)
			{
				if (n % i == 0)
				{
					n /= i;
					answer.push_back(i);
					break ;
				}
			}
		}
		for (unsigned int i = 0; i < answer.size(); i++)
			cout << answer[i] << "\\n";
	}
	return (0);
}