일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- List
- spring boot
- 스택
- math
- GC로그수집
- javascript
- Properties
- date
- Java
- Calendar
- 큐
- scanner
- deque
- CSS
- set
- JPA
- 리소스모니터링
- dfs
- union_find
- BFS
- sql
- map
- html
- alter
- Union-find
- priority_queue
- 힙덤프
- 스프링부트
- NIO
- string
- Today
- Total
목록분류 전체보기 (309)
매일 조금씩

이문제는 가장 긴 증가하는 부분수열(LIS)을 푸는 방식과 매우 비슷하다. 다만 여기선 가장 긴 감소하는 부분 수열을 찾는 문제이며 최댓값을 찾아내는 것이고 순서는 상관없기 때문에 입력받은 값을 reverse시켜서 가장 긴 증가하는 부분 수열처럼 처리하면 된다. #include #include #include #include using namespace std; int n; vector v; int main(void) { cin >> n; for (int i = 0; i > x; v.push_back(x); } // 순서를 뒤집어 '최장 증가 부분 수열' 문제로 변환 reverse(v.begin(), v.end()); // 다이나믹 프로그래밍을 위한 1차원 DP..

▶ 내 풀이 #include #include #include #include #include using namespace std; int t, n, m; const int MAX = 21; int dp[MAX][MAX]; int main(void) { cin >> t; for (int i = 0; i > n >> m; for (int j = 0; j > x; dp[j][k] = x; } } // 두번째 열부터 for (int y = 1; y < m; y++) { for (int x = 0; x < n; x++) { int max_num = ..

1. 사용자의 카카오로그인 아이디인 이메일주소를 웹의 아이디로 설정한다. 2. 만약 카카오로그인으로 로그인하는 것이 처음인 경우, 필수정보(닉네임 등)를 설정하기 위해 회원정보수정창으로 이동한다. 3. 만약 카카오로그인이 처음이 아닌 경우, 일반로그인과 같다. [설정] 가장 먼저 kakao developer에 로그인해서 애플리케이션을 하나만든다. 그러면 해당 애플리케이션은 아래처럼 앱키를 받는다. 이 중 아무거나 선택해서 사용하면 되는데 난 JavaScript 키를 사용했다. 아래의 플랫폼을 클릭한다. 플랫폼을 클릭한뒤 아래로 내리면 Web 설정이있다. 여기서 내 사이트 도메인 주소를 추가한다. (하나밖에 안됨) 난 원래 http://localhost:8081 이었는데 NCLOUD에 호스팅한 이후로 NC..

다른 사람 프로필 사진을 누르면 그 사람의 프로필 페이지로 이동이된다. 다른 사람 프로필 페이지에선 최초로 쪽지를 보낼수 있고, 쪽지함에서 쪽지를 보낼수도 있다. 다만, 새로운 메세지가 왔을 때 실시간으로 바로 반영이 되지 않고, 새로고침이 실행될때 반영이 되기때문에 몇초마다 페이지 전체 혹은 일부가 리로드 되는 코드를 추가해야한다. *** 순서 *** 1. 구현 완료 모습 2. DB 테이블 구축 3. 코드 3-1. JSP 3-2. Controller 3-3. DAO 3-4. TO 3-5. SQL(mapper) 1. 구현 완료 모습 1) 다른 사람 프로필에서 메세지 보내기 2) 메세지함에서 메세지 보내기 2. DB 테이블 구축 #######메세지 관련 DDL######### create table mes..

한 재작년이나 작년쯤 뭣도 모르고 코테를 쳤을 때.. 이런비슷한 문제들을 많이 봤다. 다이나믹 프로그래밍을 몰랐기 때문에 가장 큰 화폐단위부터 나누어 떨어지느냐 아니냐로 매달리다가 포기했던 기억이있다... 위의 문제 해결 아이디어를 보면 점화식으로 문제를 해결하는것과 같다. 아래와 같이 인덱스 값이 나오기 위한 결과값을 담을 배열을 만든다. 그 배열은 M의 최댓값이 10000이므로 크기가 M+1이고 초깃값이 전부 10001인 배열이다. 0은 어떠한 화폐단위로도 만들 수 없으므로 인덱스가 0인 자리엔 0을 넣는다. 다음 화폐 단위가 작은 것부터 반복문을 돌린다. 반복문이 시작은 화폐단위이고 끝은 M이 된다. 예를 들어, 아래처럼 화폐단위가 2이고 M이 7일 때 2부터 7까지가 된다. 아래는 화폐단위 2에 ..

다이나믹 프로그래밍으로 해결할수 있는 문제이다. 개미전사가 주어진 식량창고에서 얻을 수 있는 식량 최댓값을 구하는 문제인데 그리디나 구현으로 푸는 것보다 작은 요소의 해결책을 쌓아서 큰문제의 해결책을 찾는 다이나믹 프로그래밍이 훨씬 효율적인 문제다. 바텀업 방식으로 해결했다. #include #include #include #include #include using namespace std; int d[100]; int N; vector arr; int main() { cin >> N; for (int i = 0; i > x; arr.push_back(x); } d[0] = arr[0]; d[1] = max(arr[0], arr[1]); for (int i = ..