문제

단어 𝑆와 정수 𝑖가 주어졌을 때, 𝑆 𝑖번째 글자를 출력하는 프로그램을 작성하시오.

입력

첫째 줄에 영어 소문자와 대문자로만 이루어진 단어 𝑆가 주어진다. 단어의 길이는 최대 1000이다.

둘째 줄에 정수 𝑖가 주어진다. (1≤𝑖≤|𝑆|)

출력

 𝑆 𝑖번째 글자를 출력한다.

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in); //스캐너 생성
		String str = sc.next(); //문자를 받아서 str 변수에 입력
		char[] arr = str.toCharArray(); //str 변수를 arr 배열 값에 넣음
		int stop = sc.nextInt(); //멈출 int 변수를 생성
		char chStop = 0; //출력할 char 변수 생성
		
		for (int i = 0; i < stop; i++) {
			chStop = arr[i];
		}
		System.out.println(chStop);
	}
}

주석문 확인 ~~

문제

두 자연수 A와 B가 있을 때, A%B는 A를 B로 나눈 나머지 이다. 예를 들어, 7, 14, 27, 38을 3으로 나눈 나머지는 1, 2, 0, 2이다. 

수 10개를 입력받은 뒤, 이를 42로 나눈 나머지를 구한다. 그 다음 서로 다른 값이 몇 개 있는지 출력하는 프로그램을 작성하시오.

입력

첫째 줄부터 열번째 줄 까지 숫자가 한 줄에 하나씩 주어진다. 이 숫자는 1,000보다 작거나 같고, 음이 아닌 정수이다.

출력

첫째 줄에, 42로 나누었을 때, 서로 다른 나머지가 몇 개 있는지 출력한다.

package JavaTestBackJoon;

import java.util.Arrays;
import java.util.Scanner;

public class B3052 {

	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int[] arr = new int[10];
		int cnt = 0;

		for (int i = 0; i < arr.length; i++) {
			arr[i] = sc.nextInt();
			arr[i] %= 42;
//			System.out.print("반복문 " + arr[i] + " ");
		}
		Arrays.sort(arr);
		for (int i = 0; i < arr.length - 1; i++) {
			if (arr[i] != arr[i + 1]) {
				cnt++;
//				System.out.println("cnt는 " + cnt);
			}
		}
		System.out.println(cnt+1);
	}
}

문제

X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.

교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.

입력

입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.

출력

출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.

package JavaTestBackJoon;

import java.util.Scanner;

public class B5597 {

	public static void main(String[] args) {
//		X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.
		Scanner sc = new Scanner(System.in);
		int[] num = new int[31]; // 출석번호

		for (int i = 0; i < num.length; i++) {
			num[i] = i;
//			System.out.print(num[i]);
//			System.out.println("num은 >" + num[i]);
		}
		for (int i = 0; i < 28; i++) {
			num[sc.nextInt()] = 0;
//			System.out.print(i);
//			System.out.println("반복문 현황 " + i);
		}
//		System.out.println("입력 반복문 종료 ~~");
		for (int i = 0; i < num.length; i++) {
			if (num[i] != 0) {
				System.out.print(num[i]+" ");
			}
		}
	}
}

이 문제를 푸는 동안 쓸떼없이 여러 방면으로 접근해서 오래 걸렸는데

결국은 쉽게 생각하면 된다는 걸 깨닫는 시간이었다 ..

+ Recent posts