inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바스크립트 알고리즘 문제풀이 입문(코딩테스트 대비)

3. 최대부분증가수열(LIS)

이 방법은 잘못된 풀이 방법인가요?

231

dgkim3811

작성한 질문수 16

0

const main = (n) => {
  const memo = {};

  for (let i = 0; i < n.length; i++) {
    const biggerThanCur = Object.keys(memo).find((key) => n[i] > key);
    if (!biggerThanCur) memo[n[i]] = dfs(i, 0);
  }

  function dfs(index, count, recent = 0) {
    if (index === n.length) {
      return count;
    }

    if (n[index] > recent) {
      count++;
      recent = n[index];
    }

    return dfs(index + 1, count, recent);
  }

  let result = 0;
  for (const key in memo) {
    if (result < memo[key]) {
      result = memo[key];
    }
  }

  return result;
};

console.log(main([5, 3, 7, 8, 6, 2, 9, 4]));

javascript 코테 준비 같이 해요!

답변 1

0

김태원

안녕하세요^^

재귀가 좋으시면 해도 괜찮습니다. 영상의 방법도 잘 익히시기 바랍니다.

continue를 사용하는 이유

0

102

2

정렬 가능 여부 판단하기

0

81

2

알고리즘 학습법 관련해서 질문드립니다.

0

96

1

코드 리뷰 부탁드립니다!

0

108

1

indexOf를 사용해서 풀어보았습니다 !!

0

76

1

저는 이런식으로 구현 해보았습니다 !!

0

69

1

12,13,14 강의 소리만 나오고 검은 화면입니다

0

112

3

반복문 최소화하고 indexOf 사용해서 풀어봤습니다

0

74

1

영상 보기 전에 직접 풀어봤습니다.

0

81

1

섹션1의 17번문제 이 풀이로 풀어도 될까요?

0

145

2

정규표현식으로 처리해도 상관없나요 ?

0

129

2

3칸씩 건너뛸 수 있을 경우

0

133

2

강의에 대해 질문있습니다.

0

144

2

Object와 Set을 이용해 풀어봤습니다.

0

133

2

이렇게 해도 되나요?

0

113

2

선생님 중복 단어나 중복관련 문제들은 set을 이용하면 좋을것 같습니다.

0

149

2

이렇게 풀어도 괜찮을까요?

0

146

1

이렇게 풀어도 괜찮을까요?

0

125

1

모든 아나그램 찾기에서 시간복잡도

0

106

1

코드리뷰 부탁드립니다.

0

142

1

for loop 탈출은 return 문으로 해도 되지 않나요?

0

137

1

투포인트알고리즘으로 풀어봤습니다.

0

148

0

코드 리뷰 부탁드립니다.

0

121

1

코드 맞게 작성한 거 아닌가여??

0

151

1