본문 바로가기

전체 글141

[JAVA] 백준 2739 (구구단) 문제: N을 입력받은 뒤, 구구단 N단을 출력하는 프로그램을 작성 입력: 첫째 줄에 N이 주어진다. N은 1보다 크거나 같고, 9보다 작거나 같다. 출력: 출력형식과 같게 N*1부터 N*9까지 출력 import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; public class Main { public static void main(String[] args) throws IOException { //1. BufferedReader로 숫자를 받음 BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); int num = In.. 2022. 10. 21.
[JAVA] 2차원 배열을 Hashmap으로 문제: 2차원 배열(배열을 요소로 갖는 배열)을 입력받아 각 배열을 이용해 만든 HashMap을 리턴 public class Solution { public HashMap convertListToHashMap(String[][] arr) { HashMap result = new HashMap (); if (arr.length == 0) return result; for(int i = 0; i < arr.length; i++) { if (arr[i].length != 0) { if (!result.containsKey(arr[i][0])){ result.put(arr[i][0], arr[i][1]); } } } return result; } } 흐름 결과값을 받을 hashmap 생성 for문을 사용해서 k.. 2022. 10. 21.
[JAVA] 문자열 첫 글자 대문자로 public class Solution { public String letterCapitalize(String str) { //빈 문자열은 빈 문자열 그대로 if (str.length() == 0) return str; //split()을 사용해서 공백으로 배열 나누기 String[] words = str.split(" "); String result = ""; for (int i = 0; i < words.length; i++) { //빈 문자열은 받으면 그대로 i에 그대로 넣음 if(words[i].isEmpty()) { words[i] = words[i]; } else { //String.valueOf(words[i].charAt(0)): words배열의 i번째를 String으로 바꾼 뒤char로 .. 2022. 10. 21.
코딩테스트를 준비하자 의사코드 프로그래밍 언어로 코드를 작성하기 전에 일상 언어로 프로그램이 작동하는 논리를 먼저 작성하는 것 문제 이해 -> 의사코드 -> 개발 언어 기초적인 부분부터 구체적이고 상세하게 명령 노트북 켜는 것을 수도코드로 작성 public void openLaptop() { //노트북을 연다 //노트북의 전원 버튼을 누른다 //if (이용할 사용자가 여러명이면) 사용자를 고른다 //if (비밀번호가 있다면) 번호를 입력한다 //else (비밀번호가 없으면) 이용할 사용자만 클릭한다 //else (사용자가 1명이면) 엔터 || 클릭을 이용한다 //비밀번호 유.무 if/else문 //엔터 || 클릭을 해서 로그인을 완료한다 시간 복잡도 입력값의 변화에 따라 연산을 실행할 때, 연산 횟수에 비해 시간이 얼마만큼 .. 2022. 10. 21.
[JAVA] 백준 2441번 (별찍기 -4) import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); int count = Integer.parseInt(br.readLine()); br.close(); StringBuilder sb = new StringBuilder(); for (int i = 1; i = i; j--) { sb.append("*"); } sb.app.. 2022. 10. 21.
[JAVA] 백준 2440번 (별찍기 -3) 문제 첫째 줄에는 별 N개, 둘째 줄에는 별 N-1개, ..., N번째 줄에는 별 1개를 찍는 문제 입력: 첫째 줄에 N(1 ≤ N ≤ 100) 출력: 첫째 줄부터 N번째 줄까지 차례대로 별을 출력 import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); int count = Integer.parseInt(br.readLine.. 2022. 10. 21.
[JAVA] firstReverse 문제: 문자열을 입력받아 순서가 뒤집힌 문자열을 리턴 public class Main { public static void main(String[] args) { //배열 arr 만들기 char[] arr = str.toCharArray(); //뒤집힌 걸 받을 배열 만들기 char[] rv_arr = new char[arr.length]; //for문을 사용해서 rv_arr에 arr의 문자열을 역순으로 받음 for (int i = 0; i < arr.length; i++) { rv_arr[arr.length - 1 - i] = arr[i]; } String rv_Str = new String(rv_arr); return rv_Str; } } StringBuilder을 이용한 방법 StringBuilde.. 2022. 10. 21.
[JAVA] 백준 2439 (별찍기-2) 문제: 첫째 줄에는 별 1개, 둘째 줄에는 별 2개, N번째 줄에는 별 N개를 찍는 문제(오른쪽으로 정렬) 입력: 첫째 줄에 N(1 ≤ N ≤ 100) 출력: 첫째 줄부터 N번째 줄까지 차례대로 별을 출력 import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; public class Main { public static void main(String[] args) throws IOException { //입력을 받을 BufferedReader 생성 BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); int count.. 2022. 10. 21.
[JAVA] 선입선출 상자포장 최대값 들어온 순서대로 선입선출 포장 조건 1.동시에 최대 몇 명이 나갈 수 있는지? 2.맨 앞의 수보다 크면 나가지 못함 3.앞의 수보다 작으면 같이 나감 방법 1. for문을 사용해 배열에서 앞의 수보다 같거나 작은 경우가 나오면 배열을 나눠 따로 저장 (for문 2개 이상 사용) -> 코드가 너무 복잡해져서 방법 바꿈 2. while과 for문을 사용해서 구현 /* 조건 들어온 순서대로 선입선출 포장 동시에 최대 몇 명이 나갈 수 있는지 맨 앞의 수보다 크면 리턴되지 못하고 앞의 수보다 작으면 같이 리턴됨 */ package com.codestates.coplit; import java.util.*; public class Solution { public int paveBox(Integer[] boxes).. 2022. 10. 21.
[JAVA] 브라우저 앞,뒤로 가기 출력 과정 -1 (PREV) A [A,B] [A] [A,B] [A,B,D] [A,B] [A,B,D] [A,B] [A] CURRENT A B C B D A D A D B 1 (NEXT) [C] [A] [A] [A,D] 입력 값 A B C -1 D A -1 1 -1 -1 /* 문제: 브라우저 앞으로 가기와 뒤로 가기 만들기 조건 새 페이지에 접속: prev에 원래 / next 비움 뒤로가기: 원래 페이지를 next / prev 스택의 top으로 이동 -> prev값을 pop 앞으로 가기: 원래 페이지 prev / next 스택의 top로 이동 -> next값을 pop 뒤로가기 앞으로 가기 불가: push 안 함 첫글자에 알파벳 대문자가 아니면 false 리턴 주의사항 1. 뒤로가기 : -1, 앞으로가기 : .. 2022. 10. 21.
728x90