투 포인터(Two Pointers)
- 리스트에 순차적으로 접근해야 할 때 두 개의 점의 위치를 기록하면서 처리
- 리스트에 담긴 데이터에 순차적으로 접근해야 할 때는 시작점과 끝점 2개의 점으로 접근할 데이터의 범위를 표현할 수 있음
data:image/s3,"s3://crabby-images/481e2/481e2cffb662df42abbc23f64f383b144037b85d" alt=""
특정한 합을 가지는 '부분 연속 수열' 찾기: 문제설명
data:image/s3,"s3://crabby-images/46e73/46e736bc49e8df3a2d0ffeccc7b43bacaded2ea1" alt=""
문제해결 아이디어
data:image/s3,"s3://crabby-images/d361d/d361de2b1d8cc7b1d1621b85a66a2471cca7ba07" alt=""
data:image/s3,"s3://crabby-images/ce5d1/ce5d19ff73cdf296cb2d3575b202d1e495564294" alt=""
data:image/s3,"s3://crabby-images/cb3d8/cb3d84312a7ae9ed545e3dfca578c5434e912522" alt=""
data:image/s3,"s3://crabby-images/781db/781dbc0b2f193e25a0d89ac67ea34519e58c1b63" alt=""
data:image/s3,"s3://crabby-images/02d74/02d74637a482f9392b6d043b27060ff897ac1ab7" alt=""
data:image/s3,"s3://crabby-images/a941d/a941d5af82c5c777f74a2771989f55d6957c57ea" alt=""
data:image/s3,"s3://crabby-images/cd8d0/cd8d0f7ecf5bcfb6c7093fd2add3eade74325ebd" alt=""
data:image/s3,"s3://crabby-images/0f4f9/0f4f9d610f8beb56cf2de6cd34732150285e8aa2" alt=""
data:image/s3,"s3://crabby-images/ec4af/ec4af7bb9870e6c54b8da734e8b5afe265904337" alt=""
data:image/s3,"s3://crabby-images/dc1b5/dc1b589e200ee9290bee640f36f73130ca04262e" alt=""
코드 구현
n = 5
m = 5
data = [1,2,3,2,5]
cnt = 0
interval_sum = 0
end = 0
for start in range(n):
while interval_sum < m and end < n:
interval_sum += data[end]
end += 1
if interval_sum == m:
cnt += 1
interval_sum -= data[start]
print(cnt)
구간 합(Interval Sum)
- 구간 합 문제: 연속적으로 나열된 N개의 수가 있을 때 특정 구간의 모든 수를 합한 값을 계산하는 문제
문제 설명
data:image/s3,"s3://crabby-images/17abf/17abfb6914c22f81222efdbf4e5763ea76da50f8" alt=""
data:image/s3,"s3://crabby-images/21828/218287df5d50f5158b25252ccadf6d5a319bd341" alt=""
코드 구현
n = 5
data = [10,20,30,40,50]
sum_value = 0
prefix_sum = [0]
for i in data:
sum_value += i
prefix_sum.append(sum_value)
left = 3
right = 4
print(prefix_sum[right]-prefix_sum[left - 1])