์ „์ฒด ๊ธ€

๐Ÿฅ‡์ฝ”๋”ฉํ…Œ์ŠคํŠธ:Algorithm

[HSAT 4ํšŒ ์ •๊ธฐ ์ฝ”๋”ฉ ์ธ์ฆํ‰๊ฐ€ ๊ธฐ์ถœ] ํ†ต๊ทผ๋ฒ„์Šค ์ถœ๋ฐœ ์ˆœ์„œ ๊ฒ€์ฆํ•˜๊ธฐ

https://softeer.ai/practice/6257/history?questionType=ALGORITHM Softeer - ํ˜„๋Œ€์ž๋™์ฐจ๊ทธ๋ฃน SW์ธ์žฌํ™•๋ณดํ”Œ๋žซํผ softeer.ai์ฒ˜์Œ ์ƒ๊ฐํ•œ ํ’€์ด๊ณผ์ •์€ for๋ฌธ์„ ์„ธ ๋ฒˆ ์“ฐ๋Š” ๊ฒƒ ์ด์—ˆ๋Š”๋ฐ, O(n^3)์ด์–ด์„œ ์‹œ๊ฐ„์ดˆ๊ณผ๊ฐ€ ๋ฐœ์ƒํ•˜๋Š” ๋กœ์ง์ด์—ˆ์Šต๋‹ˆ๋‹ค.ํ’€์ด๊ณผ์ •i=0 ์„ ๊ธฐ์ค€์œผ๋กœ ๋‘ก๋‹ˆ๋‹ค.์ด๋•Œ ๋ฐฐ์—ด์˜ ๋์—์„œ ๋ถ€ํ„ฐ ๋น„๊ตํ•ด์•ผ ์‹œ๊ฐ„๋ณต์žก๋„๋ฅผ ์ค„์ผ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.1๊ณผ 3์€ arr[0] ์˜ ๊ฐ’ 4๋ณด๋‹ค ์ž‘์œผ๋ฏ€๋กœ 1์”ฉ ๋ˆ„์ ํ•ด์ค๋‹ˆ๋‹ค.   ๊ทธ ๋‹ค์Œ ์›์†Œ 5๋Š” arr[0] ๋ณด๋‹ค ํฝ๋‹ˆ๋‹ค. ๋”ฐ๋ผ์„œ 1์„ ๋ˆ„์ ํ•˜์ง€ ์•Š๊ณ  ๊ทธ๋Œ€๋กœ 2๋ฅผ ์ž…๋ ฅํ•ฉ๋‹ˆ๋‹ค.๋˜ํ•œ arr[0]๋ณด๋‹ค 5๊ฐ€ ํฌ๊ธฐ๋•Œ๋ฌธ์—, ์Šคํƒ์ •๋ ฌ์„ ์ˆ˜ํ–‰ํ•  ์ˆ˜ ์—†๋Š” ๊ฒฝ์šฐ ์ž…๋‹ˆ๋‹ค.answer ์— ๋ˆ„์ ๋œ ๊ฐ’ 2๋ฅผ ๋ˆ„์ ํ•ด์ค๋‹ˆ๋‹ค. ๊ทธ ๋‹ค์Œ ์›์†Œ 2๋Š” arr[..

๐Ÿฅ‡์ฝ”๋”ฉํ…Œ์ŠคํŠธ:Algorithm

[HSAT 1ํšŒ ์ •๊ธฐ ์ฝ”๋”ฉ ์ธ์ฆํ‰๊ฐ€ ๊ธฐ์ถœ] ๋กœ๋ด‡์ด ์ง€๋‚˜๊ฐ„ ๊ฒฝ๋กœ

https://softeer.ai/practice/6275/history?questionType=ALGORITHM Softeer - ํ˜„๋Œ€์ž๋™์ฐจ๊ทธ๋ฃน SW์ธ์žฌํ™•๋ณดํ”Œ๋žซํผ softeer.ai ํ’€์ด๊ณผ์ •์ „์ฒด์ ์ธ ํ’€์ด1. ํƒ์ƒ‰ ๊ฒฝ๋กœ์˜ ์‹œ์ž‘์ , ์‹œ์ž‘ ๋ฐฉํ–ฅ ์ฐพ๊ธฐ2. ์ฐพ์€ ๋ฐฉํ–ฅ์œผ๋กœ dfsํƒ์ƒ‰ํ•˜๊ธฐ2-1. ํ˜„์žฌ ๋ฐฉํ–ฅ์œผ๋กœ ๋‘ ์นธ ์ด๋™ํ•  ์ˆ˜ ์žˆ๋Š”์ง€ ํ™•์ธ2-2. ์˜ค๋ฅธ์ชฝ์œผ๋กœ ํšŒ์ „ ์‹œํ‚จ ๋’ค, ๋‘ ์นธ ์ด๋™ํ•  ์ˆ˜ ์žˆ๋Š”์ง€ ํ™•์ธ2-3. ์™ผ์ชฝ์œผ๋กœ ํšŒ์ „ ์‹œํ‚จ ๋’ค, ๋‘ ์นธ ์ด๋™ํ•  ์ˆ˜ ์žˆ๋Š”์ง€ ํ™•์ธ  ์ž์„ธํ•œ ํ’€์ด์‹œ์ž‘์ ์ด ๋  ์ˆ˜ ์žˆ๋Š” ์ขŒํ‘œ1. "#" ์ธ ๋ฌธ์ž์—ด2. ์ƒ, ํ•˜, ์ขŒ, ์šฐ "#" ๋ฌธ์ž์—ด์ด ํ•˜๋‚˜ ์žˆ์–ด์•ผ ํ•จ (๋‘ ๊ฐœ ์ด๋ฉด ์•ˆ๋จ) ์œ„ ๋‘ ๊ฐ€์ง€ ํŠน์ง•์„ ํ™œ์šฉํ•ด์„œ ๋ชจ๋“  ์ขŒํ‘œ์— ๋Œ€ํ•ด ํƒ์ƒ‰ํ•˜๋ฉฐ ์‹œ์ž‘์ ์„ ์ฐพ์•˜์Šต๋‹ˆ๋‹ค.static void find_start(..

๐Ÿฅ‡์ฝ”๋”ฉํ…Œ์ŠคํŠธ:Algorithm

[ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค] ์ƒ๋‹ด์› ์ธ์›

https://school.programmers.co.kr/learn/courses/30/lessons/214288 ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค์ฝ”๋“œ ์ค‘์‹ฌ์˜ ๊ฐœ๋ฐœ์ž ์ฑ„์šฉ. ์Šคํƒ ๊ธฐ๋ฐ˜์˜ ํฌ์ง€์…˜ ๋งค์นญ. ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค์˜ ๊ฐœ๋ฐœ์ž ๋งž์ถคํ˜• ํ”„๋กœํ•„์„ ๋“ฑ๋กํ•˜๊ณ , ๋‚˜์™€ ๊ธฐ์ˆ  ๊ถํ•ฉ์ด ์ž˜ ๋งž๋Š” ๊ธฐ์—…๋“ค์„ ๋งค์นญ ๋ฐ›์œผ์„ธ์š”.programmers.co.krํ’€์ด๊ณผ์ •1. ์œ ํ˜• ๋ณ„ ๋ฉ˜ํ† ์˜ ์ˆซ์ž ์กฐํ•ฉ์„ ๋‹ค ๊ตฌํ•˜๊ธฐ (์™„์ „ํƒ์ƒ‰)    1-1. ์ด๋•Œ n์€ ์ตœ๋Œ€ 20์ด๋ฉฐ k๋Š” ์ตœ๋Œ€ 5์ž…๋‹ˆ๋‹ค. ์•„๋ž˜ ์„ค๋ช…์— ์ •๋ฆฌ๋ฅผ ํ•ด๋†“์•˜๋Š”๋ฐ n-1๊ฐœ(19)์—์„œ k-1๊ฐœ(4)์˜ ์กฐํ•ฉ์„ ๋ฝ‘๋Š” ๋ชจ๋“  ๊ฒฝ์šฐ๋Š” 3,876๊ฐœ ์ž…๋‹ˆ๋‹ค.    1-2. reqs์˜ ๊ธธ์ด๋Š” ์ตœ๋Œ€ 300์ด๋ฏ€๋กœ, ๋ชจ๋“  ์กฐํ•ฉ์—์„œ ์ง€์—ฐ์‹œ๊ฐ„์„ ๊ณ„์‚ฐํ•˜๋Š” ๊ฒฝ์šฐ๋Š” 3876*300 =1,162,800 ์ž…๋‹ˆ๋‹ค.    1-3. ์ฆ‰ ์™„์ „ํƒ์ƒ‰ ..

๐Ÿฅ‡์ฝ”๋”ฉํ…Œ์ŠคํŠธ:Algorithm

[ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค] ๋‹ค๋ฆฌ๋ฅผ ์ง€๋‚˜๋Š” ํŠธ๋Ÿญ

https://school.programmers.co.kr/learn/courses/30/lessons/42583 ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค์ฝ”๋“œ ์ค‘์‹ฌ์˜ ๊ฐœ๋ฐœ์ž ์ฑ„์šฉ. ์Šคํƒ ๊ธฐ๋ฐ˜์˜ ํฌ์ง€์…˜ ๋งค์นญ. ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค์˜ ๊ฐœ๋ฐœ์ž ๋งž์ถคํ˜• ํ”„๋กœํ•„์„ ๋“ฑ๋กํ•˜๊ณ , ๋‚˜์™€ ๊ธฐ์ˆ  ๊ถํ•ฉ์ด ์ž˜ ๋งž๋Š” ๊ธฐ์—…๋“ค์„ ๋งค์นญ ๋ฐ›์œผ์„ธ์š”.programmers.co.krํ’€์ด๊ณผ์ •1. ํ์— ํŠธ๋Ÿญ์„ ์˜ฌ๋ฆฌ๊ธฐ1-1. ์˜ฌ๋ผ๊ฐˆ ์ˆ˜ ์žˆ์œผ๋ฉด ํŠธ๋Ÿญ์˜ ๋ฌด๊ฒŒ๋ฅผ offer1-2. ์˜ฌ๋ผ๊ฐˆ ์ˆ˜ ์—†์œผ๋ฉด 0์„ offer (๊ฐ€์ƒ์˜ ํŠธ๋Ÿญ)2. ํ์—์„œ ํŠธ๋Ÿญ ๋นผ์ฃผ๊ธฐํ์˜ size๊ฐ€ bridge_length์™€ ๊ฐ™์•„์ง„๋‹ค๋ฉด, ์ œ์ผ ์•ž์˜ ํ๋Š” ๋‹ค๋ฆฌ๋ฅผ ๊ฑด๋„ˆ๊ฐˆ ์ˆ˜ ์žˆ๋ฏ€๋กœ q.pollFirst()๋กœ ํ์—์„œ ๋นผ์ค˜์•ผ ํ•ฉ๋‹ˆ๋‹ค.3. truck_weights๋ฐฐ์—ด์˜ ๋งˆ์ง€๋ง‰ ์ธ๋ฑ์Šค ํŠธ๋Ÿญ ๊ณ ๋ คํ•˜๊ธฐ๋งˆ์ง€๋ง‰ ์ธ๋ฑ์Šค ํŠธ๋Ÿญ์„ ํ์— ๋„ฃ๋Š” ๊ฒฝ์šฐ..

๐Ÿ’Ž๋ฐฑ์—”๋“œ : Backend

@PathVariable, @RequestParam, @ModelAttribute

์•Œ๊ฒŒ๋œ ์ 1. @RequestParam์„ ํ†ตํ•ด์„œ ๋ฐ›์„ ์ˆ˜ ์žˆ๋Š” ๋ฐ์ดํ„ฐQuery StringForm ํ˜•์‹ ๋ฐ์ดํ„ฐ (html form)๋ฉ€ํ‹ฐํŒŒํŠธ ๋ฐ์ดํ„ฐ : multipart/form-data ํ˜•์‹์˜ ์š”์ฒญ์—์„œ ํผ ํ•„๋“œ์˜ ๋ฐ์ดํ„ฐ๋ฅผ ์ถ”์ถœํ•  ์ˆ˜ ์žˆ์Œ์œ„ ์„ธ๊ฐ€์ง€๋ฅผ ๋‹ค ๋ฐ›์„ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. 2. @RequestBody๋Š” ๋ณ€ํ™˜๊ณผ์ •, @ModelAttribute์€ ๋งตํ•‘๊ณผ์ •@RequestBodyJSON, XML, Text๋“ฑ์˜ ๋ฐ์ดํ„ฐ๊ฐ€ ์ ํ•ฉํ•œ HttpMessageConverter์„ ํ†ตํ•ด ํŒŒ์‹ฑ๋˜์–ด Java ๊ฐ์ฒด๋กœ ๋ณ€ํ™˜ ๋ฉ๋‹ˆ๋‹ค.@RequestBody๋ฅผ ์‚ฌ์šฉํ•  ๊ฐ์ฒด๋Š” ๋ฐ”์ธ๋”ฉ์„ ์œ„ํ•œ ์ƒ์„ฑ์ž๋‚˜, setter๋ฉ”์„œ๋“œ๊ฐ€ ํ•„์š” ์—†์Šต๋‹ˆ๋‹ค.๋‹จ, ์ง๋ ฌํ™”๋ฅผ ์œ„ํ•ด ๊ธฐ๋ณธ ์ƒ์„ฑ์ž์™€ ๋ฐ์ดํ„ฐ ๋ฐ”์ธ๋”ฉ์„ ์œ„ํ•œ getter๋‚˜ setter ์ค‘ 1๊ฐ€์ง€๋Š” ์ •์˜๋˜์–ด์•ผ ํ•ฉ๋‹ˆ๋‹ค..

๐Ÿ’Ž๋ฐฑ์—”๋“œ : Backend

๋กœ๊น…

๋กœ๊น…์ด ์™œ ํ•„์š”ํ• ๊นŒ?๋ฐฐํฌํ™˜๊ฒฝ์—์„œ ๋™์ž‘ ์ƒํƒœ๋ฅผ ํ™•์ธํ•˜๊ธฐ ์œ„ํ•ด์„œ ํ•„์š”ํ•ฉ๋‹ˆ๋‹ค.๊ธฐ์กด์˜ System.out.println(), System.err.println()๊ณผ ๊ฐ™์€ ํ”Œ๋กœ์šฐ๋กœ๋Š” ํ•œ๊ณ„๊ฐ€ ์žˆ์Šต๋‹ˆ๋‹ค.๋กœ๊น…์ด ๊ธฐ๋กํ•˜๋Š” ๋‘ ๊ฐ€์ง€ ์‚ฌํ•ญ์„œ๋น„์Šค ๋™์ž‘ ์ƒํƒœ์žฅ์• (exceptino || error)๋กœ๊น… ํ”„๋ ˆ์ž„์›ŒํฌSLF4JLogbackLog4jnlogSystem.out.println()๋ณด๋‹ค ์ข‹์€ ์ ์ถœ๋ ฅ ํ˜•์‹์„ ์ง€์ •ํ•  ์ˆ˜ ์žˆ์Œ๋กœ๊ทธ ๋ ˆ๋ฒจ์„ ์„ค์ •ํ•˜์—ฌ ๋‚จ๊ธฐ๊ณ  ์‹ถ์€ ๋กœ๊ทธ๋ฅผ ๋ณ„๋„๋กœ ์ง€์ •ํ•  ์ˆ˜ ์žˆ์Œ๊ฐœ๋ฐœ ์„œ๋ฒ„์—์„œ๋Š” ๋ชจ๋“  ๋กœ๊ทธ๋ฅผ ์ถœ๋ ฅํ•˜๊ณ , ์šด์˜์„œ๋ฒ„์—์„œ๋Š” ์ถœ๋ ฅํ•˜์ง€ ์•Š๋Š” ๋“ฑ ๋กœ๊ทธ๋ฅผ ์ƒํ™ฉ์— ๋งž๊ฒŒ ์กฐ์ ˆํ•  ์ˆ˜ ์žˆ๋‹ค์ฝ˜์†” ๋ฟ ์•„๋‹ˆ๋ผ, ํŒŒ์ผ์ด๋‚˜ ๋„คํŠธ์›Œํฌ๋“ฑ ๋กœ๊ทธ๋ฅผ ๋ณ„๋„์˜ ์œ„์น˜์— ๋‚จ๊ธธ ์ˆ˜ ์žˆ์Œ์„ฑ๋Šฅ๋„ System.out.println()๋ณด๋‹ค ์ข‹์Œ!๋กœ๊ทธ๋ ˆ๋ฒจ(Fatal..

๐Ÿฅ‡์ฝ”๋”ฉํ…Œ์ŠคํŠธ:Algorithm

[PCCP ๊ธฐ์ถœ๋ฌธ์ œ] 2๋ฒˆ / ์„์œ  ์‹œ์ถ”

๋ฌธ์ œ๋งํฌ : https://school.programmers.co.kr/learn/courses/30/lessons/250136# ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค์ฝ”๋“œ ์ค‘์‹ฌ์˜ ๊ฐœ๋ฐœ์ž ์ฑ„์šฉ. ์Šคํƒ ๊ธฐ๋ฐ˜์˜ ํฌ์ง€์…˜ ๋งค์นญ. ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค์˜ ๊ฐœ๋ฐœ์ž ๋งž์ถคํ˜• ํ”„๋กœํ•„์„ ๋“ฑ๋กํ•˜๊ณ , ๋‚˜์™€ ๊ธฐ์ˆ  ๊ถํ•ฉ์ด ์ž˜ ๋งž๋Š” ๊ธฐ์—…๋“ค์„ ๋งค์นญ ๋ฐ›์œผ์„ธ์š”.programmers.co.kr ํ’€์ด๊ณผ์ •๊ฐ ์—ด ๋งˆ๋‹ค ํ•˜๋‚˜์”ฉ ์•„๋ž˜๋กœ ๋‚ด๋ ค๊ฐ€๋ฉฐ ํƒ์ƒ‰์„ ์ˆ˜ํ–‰ํ•ฉ๋‹ˆ๋‹ค. ์ด๋•Œ ์ด๋ฏธ ๊ณ„์‚ฐ ๋œ ์˜์—ญ์€ ๋‹ค์‹œ ๊ณ„์‚ฐํ•˜์ง€ ์•Š๊ธฐ ์œ„ํ•ด ๋ฉ”๋ชจ๋ฆฌ์ œ์ด์…˜์„ ํ•ด์ค˜์•ผ ํ•ฉ๋‹ˆ๋‹ค. ๋ฉ”๋ชจ๋ฆฌ์ œ์ด์…˜์„ ์œ„ํ•ด ์˜์—ญ๋ฒŒ ๋ฒˆํ˜ธ๋ฅผ ํ• ๋‹นํ•˜๊ณ  HashMap์„ ํ™œ์šฉํ•ด ๊ทธ ํฌ๊ธฐ๋ฅผ ์ €์žฅํ–ˆ์Šต๋‹ˆ๋‹ค. ๋ฉ”๋ชจ๋ฆฌ์ œ์ด์…˜1. ์„์œ ์ธ ์˜์—ญ(1)์„ ๋งŒ๋‚˜๊ฒŒ ๋˜๋ฉด, ํ•ด๋‹น ์˜์—ญ์˜ ํฌ๊ธฐ๋ฅผ bfs๋กœ ํ™•์ธํ•ฉ๋‹ˆ๋‹ค. ์ด๋•Œ, ์˜์—ญ๋ณ„ ๋ฒˆํ˜ธ (์ €๋Š” -1,-2,-3 ... ์Œ์ˆ˜๋กœ ํ‘œ..

๐Ÿ–ฅ๏ธ์ปดํ“จํ„ฐ๊ณผํ•™:CS

OSI 7 Layer

1๊ณ„์ธต (Physical Layer, ๋ฌผ๋ฆฌ๊ณ„์ธต)์ง์ ‘ ์ „์„ ์œผ๋กœ ์ „๊ธฐ์  ์‹ ํ˜ธ๊ฐ€ ์ „๋‹ฌ๋˜๋Š” ๊ณ„์ธต๋‘ ๋Œ€์˜ ์ปดํ“จํ„ฐ๊ฐ€ ํ†ต์‹ ํ•˜๋ ค๋ฉด?๋ชจ๋“  ํŒŒ์ผ๊ณผ ํ”„๋กœ๊ทธ๋žจ์€ 0๊ณผ 1์˜ ๋‚˜์—ด์ด๋‹ค.๊ฒฐ๊ตญ 0๊ณผ 1๋งŒ ์ฃผ๊ณ ๋ง์„ ์ˆ˜ ์žˆ์œผ๋ฉด ๋œ๋‹ค.0๊ณผ 1์˜ ๋‚˜์—ด์„ ์•„๋‚ ๋กœ๊ทธ ์‹ ํ˜ธ๋กœ ๋ฐ”๊พธ์–ด ์ „์„ ์œผ๋กœ ํ˜๋ ค ๋ณด๋‚ด๊ณ (encoding), ์•„๋‚ ๋กœ๊ทธ ์‹ ํ˜ธ๊ฐ€ ๋“ค์–ด์˜ค๋ฉด 0๊ณผ 1์˜ ๋‚˜์—ด๋กœ ํ•ด์„ํ•˜์—ฌ(decoding) ๋ฌผ๋ฆฌ์ ์œผ๋กœ ์—ฐ๊ฒฐ๋œ ๋‘ ๋Œ€์˜ ์ปดํ“จํ„ฐ๊ฐ€ 0๊ณผ 1์˜ ๋‚˜์—ด์„ ์ฃผ๊ณ ๋ฐ›์„ ์ˆ˜ ์žˆ๊ฒŒ ํ•ด์ฃผ๋Š” ๋ชจ๋“ˆ(module)1๊ณ„์ธต ๋ชจ๋“ˆ์€ ํ•˜๋“œ์›จ์–ด์ ์œผ๋กœ ๊ตฌํ˜„๋˜์–ด ์žˆ์Œ2๊ณ„์ธต (DataLink Layer, ๋ฐ์ดํ„ฐ๋งํฌ๊ณ„์ธต)๋„คํŠธ์›Œํฌ ๊ธฐ๊ธฐ๋“ค ๊ฐ„ ์–ด๋–ป๊ฒŒ ํ†ต์‹ ํ•˜๋Š”์ง€ ๋งž์ถฐ์ฃผ๋Š” ๊ณ„์ธต1๊ณ„์ธต์˜ ๊ธฐ์ˆ ๋งŒ์œผ๋กœ๋Š” ์—ฌ๋Ÿฌ๋Œ€์˜ ์ปดํ“จํ„ฐ๊ฐ€ ํ†ต์‹ ํ•˜์ง€ ๋ชปํ•จ์Šค์œ„์น˜, ๋ผ์šฐํ„ฐ ๋ฅผ ํ†ตํ•ด์„œ ์—ฌ๋Ÿฌ๋Œ€์˜ ์ปดํ“จํ„ฐ๊ฐ€ ํ†ต์‹ ์„ ํ•  ์ˆ˜ ์žˆ์Œ๊ฐ™์€ ..

mc.thd
mincheolsong