https://www.acmicpc.net/problem/2475
[ 문제 ]
컴퓨터를 제조하는 회사인 KOI 전자에서는 제조하는 컴퓨터마다 6자리의 고유번호를 매긴다.
고유번호의 처음 5자리에는 00000부터 99999까지의 수 중 하나가 주어지며 6번째 자리에는 검증수가 들어간다.
검증수는 고유번호의 처음 5자리에 들어가는 5개의 숫자를 각각 제곱한 수의 합을 10으로 나눈 나머지이다.
예를 들어 고유번호의 처음 5자리의 숫자들이 04256이면, 각 숫자를 제곱한 수들의 합 0+16+4+25+36 = 81 을 10으로 나눈 나머지인 1이 검증수이다.
[ 입력 ]
첫째 줄에 고유번호의 처음 5자리의 숫자들이 빈칸을 사이에 두고 하나씩 주어진다.
[ 출력 ]
첫째 줄에 검증수를 출력한다.
[ 입출력 예시 ]
예제 입력 | 예제 출력 |
---|---|
0 4 2 5 6 | 1 |
- 입력된 값을 제곱한 값을 담아줄 변수(sum)을 선언한다.
- 5개의 값을 받을 것이므로 for문을 5번 돌려 값을 받아 제곱시켜서 변수 sum에 누적시킨다.
- sum을 10으로 나눈 나머지를 구한다.
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine(), " ");
int sum = 0;
for(int i=0; i<5; i++) {
sum += Math.pow(Integer.parseInt(st.nextToken()), 2);
}
System.out.println(sum % 10);
}
}