1. 제목
프로그래머스 약수의 합
2. 문제
문제 설명
정수 n을 입력받아 n의 약수를 모두 더한 값을 리턴하는 함수, solution을 완성해주세요.
제한 사항
- n은 0 이상 3000이하인 정수입니다.
3. 소스코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
#include <string>
#include <vector>
using namespace std;
int solution(int n) {
int answer = 0;
for(int i=1;i<=n;i++){
if(n%i==0){
answer += i;
}
}
return answer;
}
|
cs |
4. 해설
우선 입력받은 수를 통해, 약수를 판별해야 한다. 5로 입력을 받았다면 그의 약수는? 1과 5이다
어떻게 판별해야 할까?
=> 입력받은 n을 반복할 i를 통해 나누었을때 나머지가 = 0 이면
총 합은 = 몫과 + 나누어지는 수의 합
5. 정리
X
문제 출처: 프로그래머스 코딩 테스트 연습, 프로그래머스
'● 프로그래머스 > Level1' 카테고리의 다른 글
[프로그래머스]Level1 정수 내림차순으로 배치하기(C++) (0) | 2020.07.07 |
---|---|
[프로그래머스]Level1 서울에서 김서방 찾기(C++) (0) | 2020.07.07 |
[프로그래머스]Level1 나누어 떨어지는 숫자 배열(C++) (0) | 2020.07.07 |
[프로그래머스]Level1 문자열 다루기 기본(C++) (0) | 2020.07.07 |
[프로그래머스]Level1 문자열을 정수로 바꾸기(C++) (0) | 2020.07.07 |
댓글