□ Is Palindrome
https://neetcode.io/problems/is-palindrome
- 코드 리뷰
- 반복문을 통해서 양쪽 끝에서 시작하여 charAt과 isLetter || isDigit을 이용하여 새로문 문자열 생성
※ isLetter || isDigit 은 isLetterOrDigit으로 사용 가능
□ Two Integer Sum II
https://neetcode.io/problems/two-integer-sum-ii
- 코드 리뷰
※ 공간복잡도 O(1)의 조건이 있음
- List 생성 후 numbers배열 요소 대입
- 만약 targer - numbers[i] 가 list 내에 있으면
- 해당 indexOf를 가져오고 + 1 을 하여 answer 배열에 대입
□ Three Integer Sum
https://neetcode.io/problems/three-integer-sum
- 코드 리뷰
시간복잡도 O(n^3)를 가지는 비효율적인 코드다
- 모범 답안
- 코드 리뷰
- 배열을 우선 정렬한다.
- 반복문을 통해 세항 중 첫번째 값을 선정하는데
- nums[i] > 0 이면 무엇을 더해도 0이 될 수 없기 때문에 음수인 nums[i]를 찾는다.
- 중복된 세수의 조합을 피하기 위해 첫번째 값은 nums[i] == nums[i - 1]을 피한다.
- 이중 포인터를 이용해서
- 세수의 합이 양수인경우 r을 감소시키면서
- 음수인 경우 l을 증가시키면서 답을 찾는다.
□ Max Water Container
https://neetcode.io/problems/max-water-container
- 코드 리뷰
- 이중 반복문을 통해 좌변에 대한 모든 경우의 수를 계산
- 모범 답안
- 코드 리뷰
- 초기 가로의 길이를 배열의 최대 길이로 설정
- 세로의 길이는 좌우변 중 작은 값으로 설정
- area 값이 res값보다 커지면 res에 area값 대입
- left값과 right값을 인덱스로 갖는 heights의 값을 비교하여 작은 쪽의 값의 인덱스를 증가시키며 최대치 찾기
□ Trapping Rain Water(실패)
https://neetcode.io/problems/trapping-rain-water
- 코드 리뷰
- 반복문을 통해 인덱스가 l < r인동안 while문 실행
- l을 증가시키면서 왼쪽 기둥 찾기
- res값에 물이 들어갈 수 있는 공간(leftMax - height[l])을 더함
- r방향도 반복
'Java & Spring > 코딩테스트' 카테고리의 다른 글
3일차 - 알고리즘 코드카타 (0) | 2024.07.17 |
---|---|
2일차 - 알고리즘 코드카타 (0) | 2024.07.16 |
NeetCode - Arrays & Hashing (0) | 2024.05.27 |
프로그래머스 - 기초트레이닝 7일차(완료) (0) | 2024.05.08 |
프로그래머스 - 기초트레이닝 6일차 (0) | 2024.05.06 |