Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 람다
- 자료구조
- 정렬알고리즘
- map
- stl
- 스마트포인터
- 정렬
- 프로그래머스
- C++
- unorder_map
- 델리게이트
- 언리얼엔진구조체
- UE_LOG
- 선택정렬
- 애셋로드
- 강참조
- 약참조
- 람다사용정렬
- 크리티컬섹션
- C++최적화
- 언리얼가비지컬렉터
- UE4 커스텀로그
- 알고리즘
- UELOG
- BFS
- UML관련
- dataasset
- moreeffectiveC++
- 데이터애셋
- enumasByue
Archives
- Today
- Total
기억을 위한 기록들
[Code Wars] Sum of Digits / Digital Root (C++) 본문
https://www.codewars.com/kata/541c8630095125aba6000c00/train/cpp
문제 :
Digital root is the recursive sum of all the digits in a number.
Given n, take the sum of the digits of n. If that value has more than one digit, continue reducing in this way until a single-digit number is produced. The input will be a non-negative integer.
번역:
디지털 루트(자릿수근)는 숫자의 모든 숫자의 재귀적 합입니다.
n이 주어지면, n의 자릿수의 합을 더합니다. 만약 그 값이 한 자리 수 이상이면, 한 자리 수가 나올 때까지 이런 식으로 계속 줄여나가세요. 입력은 음이 아닌 정수가 될 것입니다.
풀이 :
주어진 n이 한자릿 수 이상(10이상) 이라면 각 자리의 수를 더하고 한자리가 나올때까지 반복한다.
* 디지털 루트라는게 https://ko.wikipedia.org/wiki/%EC%9E%90%EB%A6%BF%EC%88%98%EA%B7%BC
우리나라 말로는 자릿수근이라고 한다.
int calcFunc(int n)
{
//주어진 수의 각 자리수를 더하는 함수
int total = 0;
while(n!=0)
{
total += n % 10;
n /= 10;
}
return total;
}
int digital_root(int n)
{
int reult =n;
//한자릿수 이상이라면 계속해서 반복한다.
while(reult>=10)
{
reult = calcFunc(reult);
}
//최종적으로 나온값을 출력
return reult;
}
'Coding Test - cpp > Etc' 카테고리의 다른 글
[Code Wars] Replace With Alphabet Position(C++) (1) | 2023.12.20 |
---|---|
[Code Wars] Buying a car(C++) (0) | 2023.12.08 |
[프로그래머스 Lv 0] 안전지대 C++ (0) | 2023.11.28 |
[Code Wars] Remove the minimum(C++) (1) | 2023.11.26 |
[프로그래머스 lv 2 ] - 배달 (0) | 2021.04.26 |