Java/Java 알고리즘
백준 5355번 화성 수학 JAVA 구현해보기
kimc
2022. 6. 6. 15:20
```
백준 5355번 화성 수학 JAVA 구현해보기
```

이번 글을 통해 배워갈 내용
- 백준 5355번 풀이
https://www.acmicpc.net/problem/5355
5355번: 화성 수학
겨울 방학에 달에 다녀온 상근이는 여름 방학 때는 화성에 갔다 올 예정이다. (3996번) 화성에서는 지구와는 조금 다른 연산자 @, %, #을 사용한다. @는 3을 곱하고, %는 5를 더하며, #는 7을 빼는 연산
www.acmicpc.net
백준 5355번 화성 수학은
난이도 브론즈 등급의 문제로서
초기 숫자와 특수 연산자 @, %, #을 받고
@는 3을 곱하고, % 는 5를 더하며, #는 7을 빼는 연산자일 때
테스트 케이스마다 반복해서
최종 연산 결과를 구해주면 됩니다.
30분 정도 위에 링크를 방문하셔서 풀어보시고
안 풀리시는 경우에만 아래 해답을 봐주시면 감사하겠습니다.
스트림으로 리스트를 순회하면서
스위치 문으로 해당되는 연산자를 계산하고 결과를 구했습니다.
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;
public class Main {
public static void main(String[] args) throws IOException {
final BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
final int testcase = Integer.parseInt(br.readLine());
StringBuilder sb = new StringBuilder();
for (int i = 0; i < testcase; i++) {
String[] inputArr = br.readLine().split(" ");
final double initVal = Double.parseDouble(inputArr[0]);
final List<String> ops = Arrays.stream(inputArr).skip(1).collect(Collectors.toList());
sb.append(solution(initVal, ops)).append("\n");
}
if (sb.length() > 0) {
sb.setLength(sb.length() - 1);
}
System.out.print(sb);
}
private static String solution(double initVal, List<String> ops) {
double pVal = initVal;
for (String op : ops) {
switch (op) {
case "@": {
pVal *= 3;
break;
}
case "%": {
pVal += 5;
break;
}
case "#": {
pVal -= 7;
break;
}
default:
break;
}
}
return String.format("%.2f", ((double) Math.round(pVal * 100) / 100));
}
}
// https://codemasterkimc.tistory.com
읽어주셔서 감사합니다
무엇인가 얻어가셨기를 바라며
오늘도 즐거운 코딩 하시길 바랍니다 ~ :)
728x90