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
                            
                        
                          
                          - 개발
- 개발자
- database
- Elasticsearch
- 그리디
- Baekjoon
- 애자일기법
- 코딩테스트
- 엘라스틱서치
- 그리디알고리즘
- ES
- API
- Java
- 코드
- spring boot
- 애자일프로그래밍
- 알고리즘
- 프레임워크
- 백준
- framework
- 읽기쉬운코드
- kotlin
- JPA
- 클린코드
- 자바
- Spring
- 데이터베이스
- cleancode
- 스프링
- 코딩
                            Archives
                            
                        
                          
                          - Today
- Total
튼튼발자 개발 성장기🏋️
[2352번] 반도체 설계 본문
반응형
    
    
    
  문제 기출 : [https://www.acmicpc.net/problem/2352]

풀이 방법 #1
| [backTracking] 접근 
 2일 동안 이 문제에만 몰두했다. 그냥 생각나는대로 경우의수를 나열하여 백트래킹 기법으로 하나하나 탐색하여 체크했다. 문제는 풀었지만 당연하게도 시간초과..(정답인지도 모르겠다.) 
 그래서 다른 방법을 채택했다. | 
문제 풀이 #2
public class Main {
	private static int maxCount = 0;
	public static void backTracking(int[] input, int start, int end) throws Exception {
		int count = 1;
		int temp = end;
		int flag = 0;
		
		if(start == input.length) {
			System.out.println(maxCount);
			return;
		}
		
		for (int i = start; i < input.length; i++) {
			System.out.println(start + " / " + end + " / " + input[i]);
			if(false == (input[i] < start || input[i] >= start && input[i] <= end) || (input[i] <= start && input[i] >= end)) {
				count++;
				
				if(input[i] > end) {
					end = input[i];
				}
			}
			
			if(i == input.length - 1) {
				i = start+flag;
				end = temp;
				flag++;
				
				if(maxCount < count) {
					maxCount = count;
				}
				count = 1;
			}
		}
		
		start++;
		backTracking(input, start, input[start-1]);
	}
	public static void main(String[] args) {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		try {
			long beforeTime = System.currentTimeMillis();
			int N = Integer.parseInt(br.readLine());
			int[] input = new int[N];
			int index = -1;
			
			
			StringTokenizer tokens = new StringTokenizer(br.readLine(), " ");
			while (tokens.hasMoreTokens()) {
				index++;
				input[index] = Integer.parseInt(tokens.nextToken());
			}
			
			backTracking(input, 1, input[0]);
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			try {
				br.close();
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
	}
}
풀이 방법 #2
| [최장증가수열:LIS(Longest Increasing SubSequence)] 접근 
 선이 겹치지 않는 최대값을 구하기 위해서는 LIS를 사용해야한다. 즉, input을 받아 배열에 저장하고 해당 배열의 최장 증가 수열을 구하면 된다. 
 이 풀이 방법 역시 2일 정도 소요되었고 정말 나에겐 가장 어려운 문제가 아니었나 싶다. | 
문제 풀이 #2
public class Main {
	public static void main(String[] args) {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		try {
			int N = Integer.parseInt(br.readLine());
			int[] input = new int[N];
			int index = -1;
			
			StringTokenizer tokens = new StringTokenizer(br.readLine(), " ");
			while (tokens.hasMoreTokens()) {
				index++;
				input[index] = Integer.parseInt(tokens.nextToken());
			}
			
			int[] lisArray = new int[N];
			int lisSize = 1;
			lisArray[0] = input[0];
			
			for (int i = 1; i < N; i++) {
				if(lisArray[lisSize-1] < input[i]) {
					lisArray[lisSize] = input[i];
					
					lisSize++;
				} else {
					index = Arrays.binarySearch(lisArray, 0, lisSize, input[i]);
					index = index < 0 ? -index - 1 : index;
					lisArray[index] = input[i];
				}
			}
			
			System.out.println(lisSize);
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			try {
				br.close();
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
	}
}반응형
    
    
    
  'Business logic > 백준' 카테고리의 다른 글
| [2437번] 저울 (1) | 2020.04.19 | 
|---|---|
| [2529번] 부등호 (0) | 2020.04.16 | 
| [2217번] 로프 (2) | 2020.04.15 | 
| [1946번] 신입 사원 (0) | 2020.04.14 | 
| [1969번] DNA (0) | 2020.04.13 | 
 
                   
                   
                  