알고리즘 문제
[백준] 4539번 반올림
feelcoding
2020. 3. 20. 01:54
728x90
https://www.acmicpc.net/problem/4539
4539번: 반올림
문제 정수 x가 주어졌을 때, 10보다 크다면, 1의 자리에서 반올림하고, 결과가 100보다 크면, 10의 자리에서 반올림하고, 1000보다 크면, 100의 자리에서 반올림하고... 이와 같이 계속 반올림하는 프로그램을 작성하시오. 입력 첫째 줄에 테스트 케이스의 개수 n이 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있으며, 정수 x가 주어진다. (0 ≤ x ≤ 99999999) 출력 각 테스트 케이스마다 입력으로 주어지는 정수를 문제 설명에 나온
www.acmicpc.net
#include <iostream>
#include <vector>
using namespace std;
int main() {
cin.tie(NULL);
ios_base::sync_with_stdio(false);
int n;
cin >> n;
for (int i = 0; i < n; i++) {
int a;
cin >> a;
if (a > 10) {
a = (a + 5) / 10 * 10;
}
if (a > 100) {
a = (a + 50) / 100 * 100;
}
if (a > 1000) {
a = (a + 500) / 1000 * 1000;
}
if (a > 10000) {
a = (a + 5000) / 10000 * 10000;
}
if (a > 100000) {
a = (a + 50000) / 100000 * 100000;
}
if (a > 1000000) {
a = (a + 500000) / 1000000 * 1000000;
}
if (a > 10000000) {
a = (a + 5000000) / 10000000 * 10000000;
}
cout << a << '\n';
}
return 0;
}
728x90