알고리즘
백준 #10757 java 2023.01.20
chaewonni
2023. 1. 20. 04:56

문제만 보면 되게 쉬운 거 같지만 int형의 범위를 넘어가면 출력이 안되기에 다른 방법을 써서 풀어야했던 문제다.
따라서 문자열로 받아서 배열에 집어넣고 배열끼리 더해서 구해야겠다는 생각을 해보았다.
package boj_basic.step7;
import java.util.Scanner;
public class Q10757 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String s = sc.next();
String ss = sc.next();
int num = 0;
if(s.length()>ss.length())
num = s.length();
else
num = ss.length();
int[] arr = new int[num+1];
int[] arr2 = new int[num +1];
for(int i = 0; i<s.length(); i++) {
arr[i] = s.charAt(s.length()-i-1)-'0';
}
for(int i = 0; i<ss.length(); i++) {
arr2[i] = ss.charAt(ss.length()-i-1)-'0';
}
for(int i = 0; i<num; i++) {
if(arr[i]+arr2[i]>=10) {
arr[i]=(arr[i]+arr2[i])%10;
arr[i+1]++;
}else
arr[i]=arr[i]+arr2[i];
}
if(arr[num]>0)
System.out.print(arr[num]);
for(int i = num-1; i>=0; i--) {
System.out.print(arr[i]);
}
}
}
배열끼리 더했을 때 10이 넘는다면 그 배열은 10을 나눈 나머지를 저장하고, 그 다음배열에 +1을 더한 값을 저장해주면 된다.
근데 다른 분들의 코드를 살펴보니 자바에 BigInteger클래스가 있다고....
package boj_basic.step7;
import java.math.BigInteger;
import java.util.Scanner;
public class Q10757_1 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
BigInteger a = sc.nextBigInteger();
BigInteger b = sc.nextBigInteger();
System.out.println(a.add(b));
}
}
이렇게 간단하게도 풀 수 있는 문제였다.ㅎㅎ
그래도 문자열로 받아서 푸는 방법과 같이 똑같은 문제를 다양한 방법으로 풀어보는 것도 코딩실력 향상에 도움이 되는 것 같다 ㅎㅎ