일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- git
- Visual Studio
- Binding
- WPF
- ListView
- coding-test
- log
- nullable
- Process
- convert
- 코딩테스트
- csharp
- windows10
- windows
- tls
- Github
- C#
- algorithm
- File
- string
- programmers
- chashtag
- commit
- dotNET
- mysql
- .net
- IValueConverter
- Microsoft
- logging
- Coding
Archives
- Today
- Total
CHashtag
[프로그래머스] [C#] 3진법 뒤집기 본문
반응형
안녕하세요.
오늘은 프로그래머스 코딩테스트 연습 문제인 "3진법 뒤집기" 를 풀어 보았습니다.
문제 링크
https://programmers.co.kr/learn/courses/30/lessons/68935
문제 풀이 방법
이번 문제의 풀이는 주석으로 달아두었습니다.
또한 이번 문제는 평균 약 1.0ms 정도의 속도로 테스트를 통과하였습니다.
코드
using System;
public class Solution {
public int solution(int n)
{
int answer = 0;
int cnt = 0;
string str = string.Empty;
while (true)
{
// 3의 제곱으로 나누어지는 가장 큰 수를 찾습니다.
double temp = Math.Pow(3, cnt);
if (temp > n)
{
cnt--;
break;
}
cnt++;
}
// 3진수로 변환
for (int i = cnt; i >= 0; i--)
{
int pow = (int)Math.Pow(3, i);
for (int j = 2; j >= 0; j--)
{
if (n >= pow * j)
{
str += j;
n -= pow * j;
break;
}
if (j == 0)
{
str += "0";
}
}
}
// 다시 10진수로 변환
for (int i = 0; i < str.Length; i++)
{
int pow = (int)Math.Pow(3, i);
int num = (int)Char.GetNumericValue(str[i]);
answer += num * pow;
}
return answer;
}
}
감사합니다.
반응형
'알고리즘' 카테고리의 다른 글
[프로그래머스] [C#] 부족한 금액 계산하기 (0) | 2021.08.02 |
---|---|
[프로그래머스] [C#] 숫자 문자열과 영단어 (0) | 2021.08.02 |
[프로그래머스] [C#] 약수의 개수와 덧셈 (0) | 2021.07.07 |
[프로그래머스] [C#] 예산 (0) | 2021.07.07 |
[프로그래머스] [C#] 체육복 (0) | 2021.07.05 |