Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 프로그래머스 #아픈 동물 찾기 #mysql #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #모음 제거 #알고리즘 #자바 #java #코린이 #개발자 #study
- 프로그래머스 #알고리즘 #mysql #인기있는 아이스크림 #코린이 #개발자 #study
- 프로그래머스 #알고리즘 #mysql #
- 프로그래머스 #mysql #역순 정렬하기 #알고리즘 #코린이 #개발자 #study
- 코린이 #개발자 #study
- 프로그래머스 #mysql #동명 동물 수 찾기 #알고리즘 #코린이 #개발자
- 프로그래머스 #잡은 물고기 중 가장 큰 물고기의 길이 구하기 #알고리즘 #mysql #코린이 #개발자 #study
- 프로그래머스 #과일로 만든 아이스크림 고르기 #mysql #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #한 해에 잡은 물고기 수 구하기 #mysql #알고리즘 #코린이 #개발자 #study
- 백준 #네 번째 점 #3009 #자바 #java #알고리즘 #코린이 #개발자 #study
- 백준 #일곱 난쟁이 #2309 #자바 #java #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #조건에 맞는 회원수 구하기 #mysql #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #mysql #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #mysql #경기도에 위치한 식품창고 목록 출력하기 #알고리즘 #코린이 #개발자 #study
- 특정 옵션이 포함된 자동차 리스트 구하기 #코린이 #개발자 #study
- 백준 #4153 #직각삼각형 #알고리즘 #자바 #java #코린이 #개발자 #study
- 백준 #다이얼 #5622 #알고리즘 #자바 #java #코린이 #개발자 #study
- mysql #min() #max() #최소값 #최대값 #코린이 #개발자 #study
- 백준 #
- 프로그래머스 #잡은 물고기의 평균 길이 구하기 #mysql #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #mysql #12세 이하인 여자 환자 목록 출력하기 #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #mysql #흉부외과 또는 일반외과 의사 목록 출력하기 #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #mysql #알고리즘 #자동차 대여 기록에서 장기/단기 대여 구분하기 #코린이 #개발자 #study
- 프로그래머스 #python 개발자 찾기 #알고리즘 #mysql #코린이 #개발자 #study
- 프로그래머스 #mysql #알고리즘 #이름이 있는 동물의 아이디 #코린이 #개발자 #study
- 프로그래머스 #나이 정보가 없는 회원 수 구하기 #mysql #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #가장 큰 물고기 10마리 구하기 #mysql #알고리즘 #코린이 #개발자 #study
- 프로그래머스 #mysql #알고리즘 #어린 동물 찾기 #코린이 #개발자 #study
- 프로그래머스 #동명 동물 수 찾기 #mysql #데이터베이스 #db #코린이 #개발자 #알고리즘
Archives
- Today
- Total
luke
[백준 ] - 더하기 사이클 (1110) (자바/Java) 본문
문제 : https://www.acmicpc.net/problem/1110
문제.
풀이.
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
sc.close();
int cnt = 0;
int copy = n;
while (true) {
n = ((n % 10) * 10) + ((n / 10) + (n % 10)) % 10;
cnt++;
if (copy == n) {
break;
}
}
System.out.println(cnt);
}
}
오늘의 문제는 " 더하기 사이클 " 문제다.
문제를 풀면서 필자는 문자열로 받은 뒤 형변환을 통해 알고리즘을 짜봤지만 코드가 지저분해지고 메모리도 많이 차지하면서 복잡했다. 그러다 정수로 입력받아 풀면 보다 간단한 코드가 나오는 걸 볼 수 있어 풀었다.
그럼 바로 문제 풀이를 해보겠다.
1. n, cnt 변수들은 문제 지문을 읽으면 필수 인걸 확인할수 있다. 여기서 copy를 추가해줬는데 이유는 더하기 사이클이 돌았을 때 처음 입력한 값과 같은 값이 나오면 종료해줘야 하기 때문이다.
2.((n % 10) * 10) 은 입력한 값의 1의 자리가 새로운 10의 자리로 들어간다.
((n / 10) + (n % 10)) % 10 은 입력한 값 10의 자리와 1의 자리를 더한 값이 나와 새로운 10의 자리와 1의자리를 더해 지문에 맞는 식이 나온다.
3. 마지막으로 copy 의 값과 입력값이 같을 경우 루프 종료를 해주고 cnt 증가한 최종 값을 출력한다.
'알고리즘문제 > 백준 문제(Java)' 카테고리의 다른 글
[백준] - 완전제곱수 (1977) (자바/Java) (0) | 2024.05.15 |
---|---|
[백준] - 화성 수학 (5355) (자바/Java) (0) | 2024.05.14 |
[백준] - 슈퍼 마리오 (2851) (자바/Java) (0) | 2024.05.11 |
[백준] - 거스름돈 (5585) (자바/Java) (0) | 2024.05.10 |
[백준] - 소수 (2581) (자바/Java) (0) | 2024.05.09 |