1340번: 연도 진행바백준/문제2024. 4. 17. 11:46
Table of Contents
문제 출처 : https://www.acmicpc.net/problem/1340
언어 : Kotlin
문제 설명 :
문빙이는 새해를 좋아한다. 하지만, 이제 새해는 너무 많이 남았다. 그래도 문빙이는 새해를 기다릴 것이다.
어느 날 문빙이는 잠에서 깨면서 스스로에게 물었다. “잠깐, 새해가 얼마나 남은거지?”
이 문제에 답하기 위해서 문빙이는 간단한 어플리케이션을 만들기로 했다. 연도 진행바라는 것인데, 이번 해가 얼마나 지났는지를 보여주는 것이다.
오늘 날짜가 주어진다. 이번 해가 몇%지났는지 출력하는 프로그램을 작성하시오.
입력 :
첫째 줄에 Month DD, YYYY HH:MM과 같이 주어진다. Month는 현재 월이고, YYYY는 현재 연도이다. 숫자 네자리이다. DD, HH, MM은 모두 2자리 숫자이고, 현재 일, 시, 분이다.
Month는 January, February, March, April, May, June, July, August, September, October, November, December 중의 하나이고, 연도는 1800보다 크거나 같고, 2600보다 작거나 같다. 항상 올바른 날짜와 시간만 입력으로 주어진다.
출력 :
첫째 줄에 문제의 정답을 출력한다. 절대/상대 오차는 10-9까지 허용한다.
제한 사항 :
- 시간 제한 : 2초
- 메모리 제한 : 128MB
입출력 예 :
입력 | 출력 |
May 10, 1981 00:31 | 35.348363774733635 |
January 01, 2008 00:00 | 0.0 |
December 31, 2007 23:59 | 99.99980974124807 |
July 02, 2007 12:00 | 50.0 |
July 02, 2008 00:00 | 50.0 |
January 31, 1900 00:47 | 8.228120243531203 |
풀이 :
import java.io.BufferedReader
import java.io.BufferedWriter
import java.io.InputStreamReader
import java.io.OutputStreamWriter
fun main() = with(BufferedReader(InputStreamReader(System.`in`))) {
val bw = BufferedWriter(OutputStreamWriter(System.out))
readLine().also {
val (month, day, year, time) = it.split(" ")
val leapYearMonth = intArrayOf(31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31)
if (isLeapYear(year.toInt())) {
bw.write("%.9f".format(
toNow(leapYearMonth, monthToInt(month), day.removeSuffix(",").toInt() - 1, time.split(":").map { it.toInt() }) * 100))
} else {
leapYearMonth[1] = 28
bw.write("%.9f".format(toNow(leapYearMonth, monthToInt(month), day.removeSuffix(",").toInt() - 1, time.split(":").map { it.toInt() }) * 100))
}
}
bw.flush()
bw.close()
}
fun isLeapYear(year: Int): Boolean {
return if (year % 4 == 0) {
if (year % 400 == 0 && year % 100 == 0) true
else if (year % 400 == 0 && year % 100 != 0) true
else !(year % 400 != 0 && year % 100 == 0)
} else {
false
}
}
fun toNow(year: IntArray, month: Int, day: Int, time: List<Int>): Double {
val dayToSec = 60 * 60 * 24
var sec = 0
for (i in 0 until month - 1) {
sec += dayToSec * year[i]
}
sec += dayToSec * day
sec += time[0] * 3600 + time[1] * 60
return sec.toDouble() / (year.sum().toDouble() * dayToSec.toDouble())
}
fun monthToInt(month: String): Int {
return when (month) {
"January" -> 1
"February" -> 2
"March" -> 3
"April" -> 4
"May" -> 5
"June" -> 6
"July" -> 7
"August" -> 8
"September" -> 9
"October" -> 10
"November" -> 11
else -> 12
}
}
'백준 > 문제' 카테고리의 다른 글
9322번: 철벽 보안 알고리즘 (0) | 2024.04.17 |
---|---|
9081번: 단어 맞추기 (0) | 2024.04.17 |
12933번: 오리 (0) | 2024.04.16 |
9342번: 염색체 (0) | 2024.04.16 |
5357번: Dedupe (0) | 2024.04.16 |
@스몰스테핑 :: 작은 발걸음
포스팅이 좋았다면 "좋아요❤️" 또는 "구독👍🏻" 해주세요!