[프로그래머스] Lv. 1 정수 제곱근 판별(Kotlin)

hxeyexn·2023년 4월 5일
0
post-thumbnail

정수 제곱근 판별

문제

임의의 양의 정수 n에 대해, n이 어떤 양의 정수 x의 제곱인지 아닌지 판단하려 합니다.
n이 양의 정수 x의 제곱이라면 x+1의 제곱을 리턴하고, n이 양의 정수 x의 제곱이 아니라면 -1을 리턴하는 함수를 완성하세요.

제한 사항

  • n은 1이상, 50000000000000 이하인 양의 정수입니다.

풀이1

import kotlin.math.sqrt

class Solution {
	fun solution(n: Long): Long {
    var x = sqrt(n.toFloat()).toLong()
    
    return if (x * x == n) ((x + 1) * (x + 1)) 
    else -1
 }

풀이2

import kotlin.math.sqrt
import kotlin.math.pow

class Solution {
	fun solution(n: Long): Long {
   var x = sqrt(n.toFloat()).toLong()
   
   return if (x * x == n) (x.toFloat() + 1).pow(2).toLong()
   else -1
   }
}
  • sqrt 함수
    fun sqrt(x: Float): Float
    fun sqrt(x: Double): Double
    : 제곱근
    : 반환형은 Float 혹은 Double 형
  • pow 함수
    fun Float.pow(n: Int): Float
    fun Double.pow(n: Int): Double
    : 제곱
    : 반환형은 Float 혹은 Double 형
profile
Android Developer

0개의 댓글