| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 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 |
Tags
- K8S
- 문제해결
- ProblemSolving
- 2022
- C++
- Qualification Round
- 하늘과 바람과 별과 詩
- Code Jam 2022
- GitLab
- 리트코드
- 프로그래머스
- hackerrank
- 3D PRINTING
- leetcode
- 코딩테스트
- Kubernetes
- MySQL
- 알고리즘
- First Unique Character in a String
- Code Jam
- Algorithm
- 파이썬
- swift
- 해커랭크
- 하늘과 바람과 별과 시
- Count Monobit Integers
- Python
- ProblemSoving
- LEVEL 2
Archives
- Today
- Total
공대생의 비망록
[프로그래머스][Lv. 1] 정수의 제곱근 판별 Swift 풀이 본문
https://programmers.co.kr/learn/courses/30/lessons/12934
코딩테스트 연습 - 정수 제곱근 판별
임의의 양의 정수 n에 대해, n이 어떤 양의 정수 x의 제곱인지 아닌지 판단하려 합니다. n이 양의 정수 x의 제곱이라면 x+1의 제곱을 리턴하고, n이 양의 정수 x의 제곱이 아니라면 -1을 리턴하는 함
programmers.co.kr
풀이
간단한 문제이다.
입력으로 주어진 Int64 자료형 정수 n의 제곱근을 sqrt() 로 구한 다음, 이를 Int로 형변환한 값과 정확히 같은 지 확인해보면 정수의 제곱근 여부를 간단히 확인할 수 있다.
정수의 제곱 여부를 확인하여 맞다면 그 정수+1의 제곱을 반환하고, 그렇지 않을 경우 -1을 반환하면 된다.
끝!
|
1
2
3
4
5
6
|
import Foundation
func solution(_ n:Int64) -> Int64 {
var tmp: Double = sqrt(Double(n))
return tmp == Double(Int(tmp)) ? Int64(pow(Double(tmp + 1), 2.0)) : -1
}
|
cs |
'Programming Language > Swift' 카테고리의 다른 글
| [프로그래머스][Lv. 1] 자연수 뒤집어 배열로 만들기 Swift 풀이 (0) | 2022.03.14 |
|---|---|
| [프로그래머스][Lv. 1] 정수 내림차순으로 배치하기 Swift 풀이 (0) | 2022.03.14 |
| [프로그래머스][Lv. 1] 제일 작은 수 제거하기 Swift 풀이 (0) | 2022.03.14 |
| [프로그래머스][Lv. 1] 짝수와 홀수 Swift 풀이 (0) | 2022.03.14 |
| [프로그래머스][Lv. 1] 최대공약수와 최소공배수 Swift 풀이 (0) | 2022.03.14 |
Comments
