9월 6일 개인공부

안효빈·2022년 9월 6일
0

개인 공부

목록 보기
7/36

추상 클래스

  • 자바에서는 하나 이상의 추상 메소드를 포함하는 클래스를 가리켜 추상 클래스(abstract class)라고 합니다.

  • 이러한 추상 클래스는 객체 지향 프로그래밍에서 중요한 특징인 다형성을 가지는 메소드의 집합을 정의할 수 있도록 해줍니다.

  • 즉, 반드시 사용되어야 하는 메소드를 추상 클래스에 추상 메소드로 선언해 놓으면, 이 클래스를 상속받는 모든 클래스에서는 이 추상 메소드를 반드시 재정의해야 합니다.

추상 메소드

  • 추상 메소드(abstract method)란 자식 클래스에서 반드시 오버라이딩해야만 사용할 수 있는 메소드를 의미합니다.

  • 자바에서 추상 메소드를 선언하여 사용하는 목적은 추상 메소드가 포함된 클래스를 상속받는 자식 클래스가 반드시 추상 메소드를 구현하도록 하기 위함입니다.

  • 예를 들면 모듈처럼 중복되는 부분이나 공통적인 부분은 미리 다 만들어진 것을 사용하고,
    이를 받아 사용하는 쪽에서는 자신에게 필요한 부분만을 재정의하여 사용함으로써 생산성이 향상되고 배포 등이 쉬워지기 때문입니다.
  • 이러한 추상 메소드는 선언부만이 존재하며, 구현부는 작성되어 있지 않습니다.
    바로 이 작성되어 있지 않은 구현부를 자식 클래스에서 오버라이딩하여 사용하는 것입니다.

**선언

자바에서 추상 메소드는 다음과 같은 문법으로 선언합니다.

문법
abstract 반환타입 메소드이름();

위와 같이 선언부만 있고 구현부가 없다는 의미로 선언부 끝에 바로 세미콜론(;)을 추가합니다.

추상 메소드를 쓰는 이유

  • 자바에서 추상 메소드를 선언하여 사용하는 목적은 추상 메소드가 포함된 클래스를 상속받는 자식 클래스가 반드시 추상 메소드를 구현하도록 하기 위함입니다.
    만약 일반 메소드로 구현한다면 사용자에 따라 해당 메소드를 구현할 수도 있고, 안 할 수도 있습니다.

백준코딩 2480번

아주 개같은 주사위문제

import java.util.Scanner;

public class Main{
	
	public static void main(String[] args) {
		
		Scanner sc = new Scanner(System.in);
		
		int a = sc.nextInt();
		int b = sc.nextInt();
		int c = sc.nextInt();
		
		int[] ar = new int[] {a,b,c};
		
		if(ar[0] > ar[1]) {
			
			int d = ar[0];
			ar[0] = ar[1];
			ar[1] = d;
			
			if(ar[1] > ar[2]) {
				
				int e = ar[1];
				ar[1] = ar[2];
				ar[2] = e;
				
				if(ar[0] > ar[1]) {
					
					int f = ar[0];
					ar[0] = ar[1];
					ar[1] = f;
				}
			}
		}else if(ar[0] <= ar[1]) {
			
			if(ar[1] > ar[2]) {
				int d = ar[1];
				ar[1] = ar[2];
				ar[2] = d;
				
				if(ar[0] > ar[1]) {
					int e = ar[0];
					ar[0] = ar[1];
					ar[1] = e;
				}
			}
		} //배열정리끝
		
		
	
		if(ar[0] == ar[1]) {
			if(ar[1] == ar[2]) {
				System.out.println(10000 + ar[1]*1000);
			}else {
				System.out.println(1000+ar[1]*100);
			}
		}else if(ar[1] == ar[2]) {
			if(ar[0] != ar[1]) {
			System.out.println(1000 + ar[1]*100);}
		}else {
			System.out.println(ar[2]*100);
		}
	}
}

배열 정리먼저 하는데

배열 정리할때 예를들어 4 1 2 라면

4의값을 따로 변수선언해서 저장해놔야

1을 인덱스0번에 대입해도 4라는 값이 사라지지 않는다

이걸 생각하면서 if문을 짜서 오름차순 배열정리하도록 만든다

나중에 갯수가 늘어나면 for문으로 해야될거같은데 빡셈

배열정리 이후 a=b일떄 b=c일떄 a=b=c일때 모두 같지 않을떄를 if를 이용해서 출력

<다른사람 풀이>

if (a != b && b != c && a != c) {
	int max;
	// 만약 a > b 라면
	if (a > b) {
		// c > a > b 라면
		if (c > a) {
			max = c;
		} 
		// a > (b, c)
		else {
			max = a;
		}
	}
	// b > a 라면	
	else {
		// c > b > a 라면
		if (c > b) {
			max = c;
		}
		// b > (a, c)
		else {
			max = b;
		}
	}
	System.out.println(max * 100);
}
// 적어도 한 쌍 이상의 서로 같은 변수가 존재할 경우
else {
	// 3개의 변수가 모두 같은 경우
	if (a == b && a == c) {
		System.out.println(10000 + a * 1000);
	}
	else {
		// a가 b혹은 c랑만 같은 경우
		if(a == b || a == c) {
			System.out.println(1000 + a * 100);
		}
		// b가 c랑 같은 경우
		else {
			System.out.println(1000 + b * 100);
		}
	}
}

and or연산자는 안쓰는줄알고 일부러 지양했는데 and연산자로 더 간략하게 정리함


백준코딩 2739번

구구단

import java.util.Scanner;

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; i++) {
			
			System.out.println(N + " * " + i + " = " + N*i);
		}
		
	}
	
}

풀이

다른사람풀이 굳이 볼필요없을듯


백준코딩 10950번

무작위 수 T쌍 더하기

무작위 수 T쌍을 더하라는게 뭔지 감이 안잡힌다

다른사람 풀이를 잠깐 봤는데 그냥 수입력을 테케 수만큼 하게만들라는거였음

import java.util.Scanner;

public class Main{
	
	public static void main(String[] args) {
		
		Scanner sc = new Scanner(System.in);
		
		int T = sc.nextInt();
		
		for(int i = 1; i <= T; i++) {
			
			int a = sc.nextInt();
			int b = sc.nextInt();

			System.out.println(a+b);
		}
		sc.close();
	}
	
}

다른사람들 보니까 스캐너 인스턴스를 꼭 close()해줌

이거 안해서 틀린적은 없었는데 일단 함

Scanner클래스를 닫는 이유

  1. 닫을 필요는 없어 보입니다. 이유는 System.in으로 외부로부터

입력을 받는데 스트림을 이용해 입력을 받지만 거의 모든 입력에 

스트림 인스턴스 사용 후 실제 닫을 필요가 없다는 공식 사이트 글을 봤습니다.

리소스가 IO 채널일 때(외부 네트워크, 파일 등)만 스트림을 닫아주면 된다고 합니다.

아래는 공식 문서에서 관련 내용을 가져와 봤습니다.

Streams have a BaseStream.close() method and implement AutoCloseable, but nearly all stream instances do not actually need to be closed after use. Generally, only streams whose source is an IO channel (such as those returned by Files.lines(Path, Charset)) will require closing. Most streams are backed by collections, arrays, or generating functions, which require no special resource management. (If a stream does require closing, it can be declared as a resource in a try-with-resources statement.)

  1. 일단 파일 리소스의 경우 하나의 스레드가 스트림을 열어 사용하고 있다면

다른 스레드는 접근할 수 없게 되는 경우가 있습니다. 

또한 connection fool 이 다 차서 더이상 접근이 불가한 경우도 있습니다(DB의 경우)

위 같은 상황을 방지하기 위해 닫아주는게 아닐까 라는 생각이 듭니다. 

제가 부족해 이 부분의 상세한 내용은 여기 참고해보시면 좋을 듯 합니다.

https://madplay.github.io/post/mistakes-when-using-java-streams

[참고] : https://okky.kr/articles/915691

굳이 닫을 필요 없는데 상황에 따라 닫는게 좋을떄도 있다함


백준코딩 8393번

1부터 N까지의 합 구하기

import java.util.Scanner;

public class Main{
	
	public static void main(String[] args) {
		
		Scanner sc = new Scanner(System.in);
		
		int a = sc.nextInt();
		
		int b = 0;
		
		for(int i = 1; i <= a; i++) {
			
			b += i;
		}
		System.out.println(b);
		sc.close();
	}
	
}

수업시간에 지겹게 함


백준코딩 25304번

준원이의 코스트코 영수증

import java.util.Scanner;

public class Main{
	
	public static void main(String[] args) {
		
		Scanner sc = new Scanner(System.in);
		
		int X = sc.nextInt(); //총금액
		int N = sc.nextInt(); //몇종류샀는지
		int tot = 0;
		for(int i = 1; i <= N; i++) {
			
			int a = sc.nextInt();
			int b = sc.nextInt();
			
			int pri = a * b;
			 
			tot += pri;
		}
		
		if(X == tot) {
			System.out.println("Yes");
		} else {
			System.out.println("No");
		}
	}
}

여태까지 나온거 조금씩 섞인 내용


오느ㅜㄹ은여기까지

profile
다들 화이팅

0개의 댓글