728x90
반응형
SMALL

전체 글 314

[IT지식] 디자인 패턴[Design pattern]이란?

📌 디자인 패턴(Design pattern)이란? - 프로그램 개발에서 빈번하게 나타나는 과제를 해결하기 위한 방법 중 하나다. - 소프트웨어 개발 과정에서 같은 실수를 반복하지 않기 위해 자신들의 시행착오를 바탕으로 특정 상황에서 발생하는 문제 패턴을 발견하고 해결방안을 기록한 것을 뜻한다. - 재이용하기 좋은 형태로 특정의 규약을 묶어서 정리하여 특정한 상황에서 구조적인 문제를 해결하는 방식이다. - 즉, 소프트웨어 설계시 또는 프로그램 개발과정에서 특정한 부분에서 빈번하게 발생하는 문제를 정리하여 상황에 따라 해결할 수 있는 해결책(패턴)을 뜻한다. - 라이브러리나 프레임워크가 도와주지 못하는 부분을 도와주는 것이 바로 디자인 패턴이다. - 디자인 패턴을 완전히 익혀 두면 어떤 코드가 스파게티 코드..

[백준알고리즘] 1차원 배열 4단계 -3052번 나머지(JAVA)

📌문제 두 자연수 A와 B가 있을 때, A%B는 A를 B로 나눈 나머지 이다. 예를 들어, 7, 14, 27, 38을 3으로 나눈 나머지는 1, 2, 0, 2이다. 수 10개를 입력받은 뒤, 이를 42로 나눈 나머지를 구한다. 그 다음 서로 다른 값이 몇 개 있는지 출력하는 프로그램을 작성하시오. 📌입력 첫째 줄부터 열번째 줄 까지 숫자가 한 줄에 하나씩 주어진다. 이 숫자는 1,000보다 작거나 같고, 음이 아닌 정수이다. 📌출력 첫째 줄에, 42로 나누었을 때, 서로 다른 나머지가 몇 개 있는지 출력한다. 📌코드 import java.util.*; public class Main{ public static void main(String[] args){ Scanner sc = new Scanner(Sy..

[백준알고리즘] 1차원 배열 3단계 -2577번 숫자의 개수(JAVA)

📌문제 세 개의 자연수 A, B, C가 주어질 때 A × B × C를 계산한 결과에 0부터 9까지 각각의 숫자가 몇 번씩 쓰였는지를 구하는 프로그램을 작성하시오. 예를 들어 A = 150, B = 266, C = 427 이라면 A × B × C = 150 × 266 × 427 = 17037300 이 되고, 계산한 결과 17037300 에는 0이 3번, 1이 1번, 3이 2번, 7이 2번 쓰였다 📌입력 첫째 줄에 A, 둘째 줄에 B, 셋째 줄에 C가 주어진다. A, B, C는 모두 100보다 크거나 같고, 1,000보다 작은 자연수이다. 📌출력 첫째 줄에는 A × B × C의 결과에 0 이 몇 번 쓰였는지 출력한다. 마찬가지로 둘째 줄부터 열 번째 줄까지 A × B × C의 결과에 1부터 9까지의 숫자가 ..

[백준알고리즘] 1차원 배열 2단계 -2562번 최댓값(JAVA)

📌문제 9개의 서로 다른 자연수가 주어질 때, 이들 중 최댓값을 찾고 그 최댓값이 몇 번째 수인지를 구하는 프로그램을 작성하시오. 예를 들어, 서로 다른 9개의 자연수 3, 29, 38, 12, 57, 74, 40, 85, 61 이 주어지면, 이들 중 최댓값은 85이고, 이 값은 8번째 수이다. 📌입력 첫째 줄부터 아홉 번째 줄까지 한 줄에 하나의 자연수가 주어진다. 주어지는 자연수는 100 보다 작다. 📌출력 첫째 줄에 최댓값을 출력하고, 둘째 줄에 최댓값이 몇 번째 수인지를 출력한다. 📌코드 import java.util.*; public class Main{ public static void main(String[] args){ Scanner sc = new Scanner(System.in); in..

[백준알고리즘] 1차원 배열 1단계 -10818번 최소, 최대(JAVA)

📌문제 N개의 정수가 주어진다. 이때, 최솟값과 최댓값을 구하는 프로그램을 작성하시오. 📌입력 첫째 줄에 정수의 개수 N (1 ≤ N ≤ 1,000,000)이 주어진다. 둘째 줄에는 N개의 정수를 공백으로 구분해서 주어진다. 모든 정수는 -1,000,000보다 크거나 같고, 1,000,000보다 작거나 같은 정수이다. 📌출력 첫째 줄에 주어진 정수 N개의 최솟값과 최댓값을 공백으로 구분해 출력한다. Arrays.sort( ); --> java.util.Arrays 유틸리티 클래스를 사용 --> 배열을 오름차순으로 정렬해준다. 📌코드 import java.util.*; public class Main{ public static void main(String[] args){ Scanner sc = new S..

[백준알고리즘] 반복문 14단계 -1110번 더하기 사이클(JAVA)

📌문제 0보다 크거나 같고, 99보다 작거나 같은 정수가 주어질 때 다음과 같은 연산을 할 수 있다. 먼저 주어진 수가 10보다 작다면 앞에 0을 붙여 두 자리 수로 만들고, 각 자리의 숫자를 더한다. 그 다음, 주어진 수의 가장 오른쪽 자리 수와 앞에서 구한 합의 가장 오른쪽 자리 수를 이어 붙이면 새로운 수를 만들 수 있다. 다음 예를 보자. 26부터 시작한다. 2+6 = 8이다. 새로운 수는 68이다. 6+8 = 14이다. 새로운 수는 84이다. 8+4 = 12이다. 새로운 수는 42이다. 4+2 = 6이다. 새로운 수는 26이다. 위의 예는 4번만에 원래 수로 돌아올 수 있다. 따라서 26의 사이클의 길이는 4이다. N이 주어졌을 때, N의 사이클의 길이를 구하는 프로그램을 작성하시오. 📌입력 첫..

[백준알고리즘] 반복문 13단계 -10951번 A+B - 4(JAVA)

📌문제 두 정수 A와 B를 입력받은 다음, A+B를 출력하는 프로그램을 작성하시오. 📌입력 입력은 여러 개의 테스트 케이스로 이루어져 있다. 각 테스트 케이스는 한 줄로 이루어져 있으며, 각 줄에 A와 B가 주어진다. (0 < A, B < 10) 📌출력 각 테스트 케이스마다 A+B를 출력한다. *** has next() ***** hasNext뒤로 Boolean, Double, Int 등등 자료형이 붙은 건 입력된 값이 그 자료형일 경우에는 true값을 반환하고 아닐 경우 false를 반환한다. 예를 들어 hasNextInt() 값을 출력할 때 정수가 들어오면 true, 입력이 없거나 정수 외의 값이 들어올 경우 false를 반환한다. 📌코드 import java.util.*; public class M..

[백준알고리즘] 반복문 12단계 - 10952번 A+B - 5(JAVA)

📌문제 두 정수 A와 B를 입력받은 다음, A+B를 출력하는 프로그램을 작성하시오. 📌입력 입력은 여러 개의 테스트 케이스로 이루어져 있다. 각 테스트 케이스는 한 줄로 이루어져 있으며, 각 줄에 A와 B가 주어진다. (0 < A, B < 10) "입력의 마지막에는 0 두 개가 들어온다." 📌출력 각 테스트 케이스마다 A+B를 출력한다. 0 0이 입력될 때까지 A+B를 연산하는 문제이기에 while문 안에 break문을 사용한다. 📌코드 import java.util.*; public class Main{ public static void main(String[] args) { Scanner sc = new Scanner(System.in); while(true){ int a= sc.nextInt(); ..

[백준알고리즘] 반복문 11단계 - 10871번 X보다 작은 수(JAVA)

📌문제 정수 N개로 이루어진 수열 A와 정수 X가 주어진다. 이때, A에서 X보다 작은 수를 모두 출력하는 프로그램을 작성하시오. 📌입력 첫째 줄에 N과 X가 주어진다. (1 ≤ N, X ≤ 10,000) 둘째 줄에 수열 A를 이루는 정수 N개가 주어진다. 주어지는 정수는 모두 1보다 크거나 같고, 10,000보다 작거나 같은 정수이다. 📌출력 X보다 작은 수를 입력받은 순서대로 공백으로 구분해 출력한다. X보다 작은 수는 적어도 하나 존재한다. 📌코드 import java.util.*; public class Main{ public static void main(String[] args){ Scanner sc = new Scanner(System.in); int n = sc.nextInt(); int ..

[백준알고리즘] 반복문 10단계 - 2439번 별 찍기 - 2(JAVA)

📌문제 첫째 줄에는 별 1개, 둘째 줄에는 별 2개, N번째 줄에는 별 N개를 찍는 문제 하지만, 오른쪽을 기준으로 정렬한 별(예제 참고)을 출력하시오. 📌입력 첫째 줄에 N(1 ≤ N ≤ 100)이 주어진다. 📌출력 첫째 줄부터 N번째 줄까지 차례대로 별을 출력한다. 📌코드 import java.util.*; public class Main{ public static void main(String[] args){ Scanner sc = new Scanner(System.in); int n = sc.nextInt(); for(int i=1; i

[백준알고리즘] 반복문 9단계 - 2438번 별 찍기 - 1(JAVA)

📌문제 첫째 줄에는 별 1개, 둘째 줄에는 별 2개, N번째 줄에는 별 N개를 찍는 문제 📌입력 첫째 줄에 N(1 ≤ N ≤ 100)이 주어진다. 📌출력 첫째 줄부터 N번째 줄까지 차례대로 별을 출력한다. **** 이중 for문의 개념을 정확히 하고 가야한다 !!! ******* 📌코드 import java.util.*; public class Main{ public static void main(String[] args){ Scanner sc = new Scanner(System.in); int n = sc.nextInt(); for(int i=1; i

[백준알고리즘] 반복문 8단계 - 11022번 A+B - 8(JAVA)

📌문제 두 정수 A와 B를 입력받은 다음, A+B를 출력하는 프로그램을 작성하시오. 📌입력 첫째 줄에 테스트 케이스의 개수 T가 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있으며, 각 줄에 A와 B가 주어진다. (0 < A, B < 10) 📌출력 각 테스트 케이스마다 "Case #x: A + B = C" 형식으로 출력한다. x는 테스트 케이스 번호이고 1부터 시작하며, C는 A+B이다. 📌코드 import java.util.*; public class Main{ public static void main(String[] args){ Scanner sc = new Scanner(System.in); int n = sc.nextInt(); for(int i=1; i

[백준알고리즘] 반복문 7단계 - 11021번 A+B - 7(JAVA)

📌문제 두 정수 A와 B를 입력받은 다음, A+B를 출력하는 프로그램을 작성하시오. 📌입력 첫째 줄에 테스트 케이스의 개수 T가 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있으며, 각 줄에 A와 B가 주어진다. (0 < A, B < 10) 📌출력 각 테스트 케이스마다 "Case #x: "를 출력한 다음, A+B를 출력한다. 테스트 케이스 번호는 1부터 시작한다. 📌코드 import java.util.*; public class Main{ public static void main(String[] args){ Scanner sc = new Scanner(System.in); int n = sc.nextInt(); for(int i=1; i

[읽을거리] “시작이 반”보다 중요한 것: 중간을 견디는 힘

https://ppss.kr/archives/237681 “시작이 반”보다 중요한 것: 중간을 견디는 힘 나는 개인적으로 '시작이 반'이라는 말을 무척 신뢰하는 편이다. 그런데 그에 못지않게 '중간이 가장 넘기기 어렵다'는 것도 자주 느낀다. 무엇이든 언젠가 하고 싶었던 마음을 기억하고 있다면 ppss.kr 삶은 늘 선택의 연속이다. 어떤 일이 내게 어울리는 것일까, 이게 나의 길인가, 내가 올바른 선택을 했는가 고민하게 된다. 어떤 일이든 중간의 지옥을 지나 보지 않으면, 그 일이 나에게 어울리는지조차 알 수 없다. 그 후 나오는 결과와 반응을 보고서야, 이 일이 내게 어울리는 것이었는지 비로소 알 수 있게 되는 것이다

Odds and Ends 2022.06.15

[백준알고리즘] 반복문 6단계 - 2742번 기찍 N(JAVA)

📌문제 자연수 N이 주어졌을 때, N부터 1까지 한 줄에 하나씩 출력하는 프로그램을 작성하시오. 📌입력 첫째 줄에 100,000보다 작거나 같은 자연수 N이 주어진다. 📌출력 첫째 줄부터 N번째 줄 까지 차례대로 출력한다. 📌코드 import java.util.*; public class Main{ public static void main(String[] args){ Scanner sc = new Scanner(System.in); int n = sc.nextInt(); for(int i=n; i>0; i--){ System.out.println(i); } } } import java.io.*; public class Main{ public static void main(String[] args)thr..

[백준알고리즘] 반복문 5단계 - 2741번 N 찍기(JAVA)

📌문제 자연수 N이 주어졌을 때, 1부터 N까지 한 줄에 하나씩 출력하는 프로그램을 작성하시오. 📌입력 첫째 줄에 100,000보다 작거나 같은 자연수 N이 주어진다. 📌출력 첫째 줄부터 N번째 줄 까지 차례대로 출력한다. 📌코드 import java.util.*; public class Main{ public static void main(String[] args){ Scanner sc = new Scanner(System.in); int n = sc.nextInt(); for( int i=1; i

728x90
반응형
LIST