2021-03-20(Sat)

ν•­λͺ©

λ‚΄μš©

ν•™μŠ΅ λ‚ μ§œ

2021-03-20(ν† )

ν•™μŠ΅ μ‹œκ°„

11:00~24:00

ν•™μŠ΅ λ²”μœ„ 및 주제

λΉ…μ˜€, python

ν•™μŠ΅ λͺ©ν‘œ

λΉ…μ˜€μ™€ python의 ν—·κ°ˆλ¦¬λŠ” 뢀뢄을 νŒŒμ•…ν•œλ‹€.

λ™λ£Œ ν•™μŠ΅ 방법

-

상세 ν•™μŠ΅ λ‚΄μš©

μ½”λ”©ν…ŒμŠ€νŠΈ 문제λ₯Ό ν’€λ˜ 쀑 μ‹œκ°„λ³΅μž‘λ„κ°€ μ• λ§€ν•œ 지점이 μžˆμ–΄μ„œ λ‹€μ‹œ ν•œλ²ˆ ν•™μŠ΅μ„ μ§„ν–‰ν•˜μ˜€λ‹€. 이후 ν”„λ‘œκ·Έλž˜λ¨ΈμŠ€ μ½”λ”©ν…ŒμŠ€νŠΈ μ—°μŠ΅μ˜ ν•΄μ‹œ, μŠ€νƒ 문제λ₯Ό ν’€μ—ˆλ‹€.

μ‹œκ°„ λ³΅μž‘λ„λž€?

μ•Œκ³ λ¦¬μ¦˜μ΄ 문제λ₯Ό ν•΄κ²°ν•˜κΈ° μœ„ν•œ μ‹œκ°„(μ—°μ‚°)의 횟수λ₯Ό λ§ν•œλ‹€. μ•Œκ³ λ¦¬μ¦˜μ€ 'μ‹œκ°„κ³Ό 곡간이 νŠΈλ ˆμ΄λ“œμ˜€ν”„' 관계이기 λ•Œλ¬Έμ—, μˆ˜ν–‰μ‹œκ°„κ³Ό λ©”λͺ¨λ¦¬ μ‚¬μš©λŸ‰μ„ ν‰κ°€κΈ°μ€€μœΌλ‘œ λ‘”λ‹€.

  • μ‹œκ°„ λ³΅μž‘λ„(Time Complexity): μˆ˜ν–‰μ‹œκ°„μ— ν•΄λ‹Ή

  • 곡간 λ³΅μž‘λ„(Space Complexity): λ©”λͺ¨λ¦¬ μ‚¬μš©λŸ‰μ— ν•΄λ‹Ή

μœ„ λ³΅μž‘λ„λ“€μ€ μž…λ ₯의 크기가 μΆ©λΆ„νžˆ 클 λ•Œ μ˜λ―Έμžˆλ‹€.

λΉ…μ˜€

λΉ…μ˜€(O, big-O)λž€ μž…λ ₯값이 λ¬΄ν•œλŒ€λ‘œ ν–₯ν•  λ•Œ ν•¨μˆ˜μ˜ μƒν•œμ„ μ„€λͺ…ν•˜λŠ” μˆ˜ν•™μ  ν‘œκΈ° 방법이닀.

λΉ…μ˜€λŠ” κ°€μž₯ 늦게 싀행될 λ•Œ, 즉 μƒν•œ(Upper Bound)을 μ˜λ―Έν•œλ‹€. 이외에도 κ°€μž₯ 빨리 싀행될 λ•Œ, 즉 ν•˜ν•œ(Lower Bound)을 λ‚˜νƒ€λ‚΄λŠ” λΉ…μ˜€λ©”κ°€, 평균을 μ˜λ―Έν•˜λŠ” 빅세타가 μžˆλŠ”λ°, 보톡 평균적인 μ‹œκ°„λ³΄λ‹€λŠ” μƒν•œ μ‹œκ°„μœΌλ‘œ λ‹¨μˆœν™”ν•΄μ„œ 주둜 ν‘œν˜„ν•œλ‹€.

μƒν•œμ„ μ΅œμ•…μ˜ κ²½μš°μ™€ ν˜Όλ™ν•˜μ§€ 말자. λΉ…μ˜€ ν‘œκΈ°λ²•μ€ μ •ν™•ν•˜κ²Œ μ“°κΈ°μ—λŠ” λ„ˆλ¬΄ κΈΈκ³  λ³΅μž‘ν•œ ν•¨μˆ˜λ₯Ό 'μ λ‹Ήνžˆ μ •ν™•ν•˜κ²Œ' ν‘œν˜„ν•˜λŠ” 방법일 뿐, μ΅œμ•…μ˜ 경우/평균적인 경우의 μ‹œκ°„ λ³΅μž‘λ„μ™€λŠ” μ•„λ¬΄λŸ° 관계가 μ—†λŠ” κ°œλ…μ΄λΌλŠ” 점에 μœ μ˜ν•΄μ•Ό ν•œλ‹€. μ΅œμ„ μ˜ κ²½μš°μ—λ„ μƒν•œμ΄ μ‘΄μž¬ν•˜κ³ , μ—­μ‹œ 평균, μ΅œμ•…μ˜ κ²½μš°μ—λ„ μƒν•œμ΄ μ‘΄μž¬ν•œλ‹€. λΉ…μ˜€ ν‘œκΈ°λ²•μ€ μ£Όμ–΄μ§„(μ΅œμ„ /μ΅œμ•…/평균) 경우의 μˆ˜ν–‰ μ‹œκ°„μ˜ μƒν•œμ„ λ‚˜νƒ€λ‚Έλ‹€.

λΆ„ν•  μƒν™˜ 뢄석

λΉ…μ˜€μ™€ ν•¨κ»˜ ν•¨μˆ˜μ˜ λ™μž‘μ„ μ„€λͺ…ν•  λ•Œ μ€‘μš”ν•œ 뢄석 방법 쀑 ν•˜λ‚˜μ΄λ‹€. μ‹œκ°„ λ˜λŠ” λ©”λͺ¨λ¦¬λ₯Ό λΆ„μ„ν•˜λŠ” μ•Œκ³ λ¦¬μ¦˜μ˜ λ³΅μž‘λ„λ₯Ό 계산할 λ•Œ, μ•Œκ³ λ¦¬μ¦˜ 전체λ₯Ό 보지 μ•Šκ³  μ΅œμ•…μ˜ κ²½μš°λ§Œμ„ μ‚΄νŽ΄λ³΄λŠ” 것은 μ§€λ‚˜μΉ˜κ²Œ λΉ„κ΄€μ μ΄λΌλŠ” 이유둜 λΆ„ν•  μƒν™˜ 뢄석 방법이 λ“±μž₯ν•˜λŠ” 계기가 됐닀. κ°€λ Ή '동적 λ°°μ—΄'의 경우 더블링이 μΌμ–΄λ‚˜λŠ” 일은 μ–΄μ©Œλ‹€ ν•œ λ²ˆλΏμ΄μ§€λ§Œ, 이둜 인해 'μ•„μ΄ν…œ μ‚½μž… μ‹œ μ‹œκ°„ λ³΅μž‘λ„λŠ” O(n)이닀.'라고 μ–˜κΈ°ν•˜λŠ” 건 μ§€λ‚˜μΉ˜κ²Œ 비관적이고 μ •ν™•ν•˜μ§€λ„ μ•Šλ‹€. λΆ„ν•  μƒν™˜μ€ μ΅œμ•…μ˜ 경우λ₯Ό μ—¬λŸ¬ λ²ˆμ— 걸쳐 골고루 λ‚˜λˆ μ£ΌλŠ” ν˜•νƒœλ‘œ μ•Œκ³ λ¦¬μ¦˜μ˜ μ‹œκ°„ λ³΅μž‘λ„λ₯Ό 계산할 수 μžˆλ‹€.

자 이제 파이썬 μ—°μ‚°λ“€μ˜ μ‹œκ°„ λ³΅μž‘λ„λ₯Ό ν™•μΈν•΄λ³΄μž.

리슀트

μ—°μ‚°

μ‹œκ°„ λ³΅μž‘λ„

len(a)

O(1)

a[i]

O(1)

a[i:j]

O(j-i)

elem in a

O(n)

a.count(elem)

O(n)

a.index(elem)

O(n)

a.append(elem)

O(1)

a.pop()

O(1)

a.pop(0)

O(n)

del a[i]

O(n)

a.sort()

O(nlogn)

min(a), max(a)

O(n)

a.reverse()

O(n)

λ”•μ…”λ„ˆλ¦¬

μ—°μ‚°

μ‹œκ°„ λ³΅μž‘λ„

len(a)

O(1)

a[key]

O(1)

a[key] = value

O(1)

key in a

O(1)

λ¬Όλ‘  μ΅œμ•…μ˜ κ²½μš°μ—” O(n)이 될 수 μžˆλ‹€.

ν•™μŠ΅ λ‚΄μš©μ— λŒ€ν•œ 개인적인 총평

μ½”λ”© ν…ŒμŠ€νŠΈ 문제λ₯Ό ν‘ΈλŠ”κ²Œ 즐겁닀. κ·Έ λ™μ•ˆ ν”„λ‘œμ νŠΈλ₯Ό ν•˜λŠλΌ κΎΈμ€€νžˆ ν•˜μ§€ λͺ»ν–ˆλŠ”λ° μ΄μ œλŠ” 정말 맀일 문제λ₯Ό ν’€μ–΄μ•Όκ² λ‹€ :) python λ©”μ„œλ“œλ“€μ΄ λ„ˆλ¬΄ νŽΈν•˜κ³  λ‚΄λΆ€ λ™μž‘λ„ μ˜ˆμΈ‘μ€ λ˜μ§€λ§Œ μ‹œκ°„ λ³΅μž‘λ„λ₯Ό μ •ν™•νžˆ κΎ€κ³  μžˆλŠ” λŠλ‚Œμ΄ λ“€μ§€ μ•Šμ•˜λ‹€. μ• μ΄ˆμ— μ‹œκ°„ λ³΅μž‘λ„λž€ 뭐지? λ‚΄κ°€ 정말 μ œλŒ€λ‘œ λ‹΅λ³€ν•  수 μžˆλ‚˜? ν•˜λŠ” 의문이 λ“€μ–΄μ„œ λ‹€μ‹œ ν•™μŠ΅ν–ˆλŠ”λ° λ§Œμ‘±μŠ€λŸ½λ‹€. μ΄λŸ°μ‹μœΌλ‘œ λ‚΄κ°€ λͺ¨λ₯΄λŠ” 뢀뢄을 λ‹€μ‹œκΈˆ λŒμ•„λ³΄κ³  μ œλŒ€λ‘œ ν•™μŠ΅ν•΄ λ‚˜κ°€μ•Όκ² λ‹€.

λ‹€μŒ ν•™μŠ΅ κ³„νš

  • λ””μžμΈνŒ¨ν„΄ ν•™μŠ΅

Last updated

Was this helpful?