[백준][DP] 9251 LCS 알고리즘

2017. 4. 20. 22:50·알고리즘/백준

LCS(Longest Common Subsequence)는 다이나믹 프로그래밍을 이용한 알고리즘 문제 풀이에 자주 이용된다. 


이는 문자열 두개를 비교하여 순서대로 있는 가장 긴 문자의 수를 세는 것이다. 


배열을 만들어서 문자가 일치할 때는 좌측 상단의 값에 +1을 하여 주고, 

일치 하지 않으면 좌측 또는 상단의 값 중 더 큰값을 선택하여 준다. 

이를 끝까지 반복하여 나오는 가장 큰 수가 LCS 값이 된다. 



import java.util.Scanner;


public class Problem9251 {


public static void main(String[] args) {


Scanner sc = new Scanner(System.in);


String str1 = sc.nextLine();

String str2 = sc.nextLine();

sc.close();


int[][] dp = new int[str1.length() + 1][str2.length() + 1];


for (int x = 1; x <= str1.length(); x++) {


char c1 = str1.charAt(x - 1);


for (int y = 1; y <= str2.length(); y++) {

char c2 = str2.charAt(y - 1);


if (c1 == c2) {

// 값이 같으면 좌측 대각선 위의 값 + 1

dp[x][y] = dp[x - 1][y - 1] + 1;

} else {

// 값이 다르면 좌측(x-1), 상단(y-1)의 값중 더 큰 값

dp[x][y] = Math.max(dp[x - 1][y], dp[x][y - 1]);

}

}

}


System.out.println(dp[str1.length()][str2.length()]);

}

}



http://twinw.tistory.com/126

https://www.acmicpc.net/problem/9251


반응형
저작자표시 비영리 (새창열림)

'알고리즘 > 백준' 카테고리의 다른 글

[백준][위상정렬, DAG] 2252 줄세우기  (0) 2017.06.20
[백준][다이나믹] 1520 내리막길  (0) 2017.06.20
[백준][다이나믹] 2156 포도주 시식  (0) 2017.06.19
[백준] 1003 피보나치 함수  (0) 2017.06.01
[백준] 1932 숫자삼각형  (0) 2017.05.31
'알고리즘/백준' 카테고리의 다른 글
  • [백준][다이나믹] 1520 내리막길
  • [백준][다이나믹] 2156 포도주 시식
  • [백준] 1003 피보나치 함수
  • [백준] 1932 숫자삼각형
hs_seo
hs_seo
Hello World!
    반응형
  • hs_seo
    개발자로 살아남기
    hs_seo
  • 전체
    오늘
    어제
    • 전체 (1140)
      • 개발자 (21)
        • 개발에 유의할 점 (0)
        • 면접 (5)
      • IT 소식 (5)
        • 업계 (1)
      • java (51)
        • 디자인패턴 (3)
        • apache-common (1)
      • 개념 (47)
        • 자료구조 (4)
        • 함수형사고 (8)
        • 디자인패턴 (1)
      • 데이터분석 (1)
      • python (67)
        • 코드조각 (12)
        • 라이브러리 (2)
      • 빅데이터 (418)
        • zookeeper (5)
        • hadoop (78)
        • hdfs (12)
        • hive (127)
        • hbase (16)
        • spark (40)
        • scala (4)
        • trino (3)
        • oozie (41)
        • Hue (9)
        • R (5)
        • sqoop (6)
        • flume (3)
        • elasticsearch (2)
        • airflow (16)
        • kafka (3)
        • kubernetes (10)
        • openstack (3)
        • flink (2)
        • redis (2)
      • 빅데이터 강좌 (2)
      • 알고리즘 (131)
        • 알고리즘 (1)
        • 백준 (61)
        • 정올 (41)
        • 더블릿 (5)
        • 프로그래머스 (1)
      • 프로그래밍 언어 (30)
        • go (4)
        • js (9)
        • .Net (6)
        • Jsp (1)
        • ansible (3)
        • terraform (6)
      • Tools (56)
        • docker (2)
        • macbook (6)
        • maven (3)
        • sublime (1)
      • 프레임워크 (25)
        • [JS] angularjs (2)
        • [JS] node.js (19)
        • [Java] spring (2)
        • Android (2)
      • 데이타베이스 (43)
        • SQLD (5)
        • Oracle (1)
        • MySQL (8)
        • ADsP (2)
      • 리눅스 (25)
        • Bash (61)
      • GCP (5)
      • AWS (34)
        • EC2 (2)
        • EMR (14)
      • 정보보안기사 (4)
        • 네트워크 (1)
      • 개인 (80)
        • 업무실수 (0)
        • 책 (9)
        • 교육 (3)
        • 여행 (17)
        • 영화 (12)
        • 음악 (2)
        • 피규어 (4)
        • 게임 (3)
        • 생각 (7)
        • 기타 (10)
        • 좋은글 (5)
        • 좋은 사이트 (2)
  • 블로그 메뉴

    • 홈
    • 태그
    • 미디어로그
    • 위치로그
    • 방명록
  • 링크

    • 빅데이터-하둡,하이브로 시작하기
    • 빅데이터-스칼라, 스파크로 시작하기
    • Kaggle에서 파이썬으로 데이터 분석 시작하기
    • 쉘스크립트 개발 시작하기
    • 개발자가 데이터 분석 준전문가 되기
    • 데브쿠마
  • 공지사항

  • 인기 글

  • 태그

    error
    Python
    emr
    HIVE
    AWS
    백준
    airflow
    Tez
    Linux
    mysql
    알고리즘
    하이브
    파이썬
    oozie
    오류
    java
    nodejs
    hbase
    k8s
    Hadoop
    다이나믹
    SPARK
    bash
    정올
    HDFS
    S3
    ubuntu
    build
    yarn
    하둡
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
hs_seo
[백준][DP] 9251 LCS 알고리즘
상단으로

티스토리툴바