1) 지식 창고는 본인이 작성한 콘텐츠(팁/노하우/리소스/강좌 등)을 무료 혹은 가상화폐인 납포인트를 통해 공유하는 공간입니다.
2) 본인이 작성한 콘텐츠에 대해서만 지식 창고에 등록할 수 있으며, 저작권에 위배되는 콘텐츠는 사전경고 없이 삭제될 수 있습니다.
3) 콘텐츠 구매 및 첨부파일 다운로드는 회원그룹 '연구원' 이상 가능하오니, 경험치를 쌓아 진급한 후에 이용 부탁드립니다.
4) 무료 콘텐츠의 본문은 구매절차 없이 즉시 이용할 수 있으며, 판매 납포인트가 있는 콘텐츠는 구매 후 이용할 수 있습니다.
5) 콘텐츠 판매에 따른 납포인트 수익은 지정한 비율(50%)에 따라 판매자에게 지급하며, 납포인트 수익을 통해 진급을 빨리할 수 있습니다.
6) 구매 후 평가를 하면 구매 납포인트의 20%를 돌려 드립니다.
판매자 | 뺘쑝 | 판매 납포인트 | 무료 | 평점 | 0점 / 총 0명 참여 |
---|
자, 지난번 강좌에 나왔던 연습문제는 푸셨는가?
그럼 풀이법에 대해 설명하도록 하겠다.
이 문제도 동적계획법으로 풀린다.(당연하지.. 동적계획법 강좌에 나온 문젠데) 풀이법은 1차원 Up sequence문제와 별로 다를 것이 없다. 우선 이차원 배열 L(2차원 버젼이므로)을 다음과 같이 잡는다.
L[i , j] = i행 j열에 있는 숫자로 끝나는 오름차순 수열의 최대길이
1차원 버젼과 별로 다르지 않다.
그럼 점화식은?
L[i , j] = 1
L[i , j] = maximum( L[k1 , k2] + 1 )
역시 1차원 버젼과 다를것은 별로 없다.(음.. 그러고 보니 "다를것이 없다"라는 말을 지난 강좌에서부터 너무 많이 쓰고 있는 듯..-_-) 그 전까지의 최대길이에 조건을 만족할 경우 +1해주면 되는 것이다.
그럼 소스를 보자.
program Upsequence_2D;
const
n=5;
data : array[1..n,1..n] of integer =(
(1,2,3,4,5),
(8,5,4,10,9),
(7,2,9,3,20),
(21,22,6,19,11),
(10,5,20,12,11)
);
var
L : array[1..n,1..n] of integer;
i,j,k1,k2 : integer;
max : integer;