์ „์ฒด ๊ธ€ 130

[์ธํ”„๋Ÿฐ ์„น์…˜8] ๋™์ „๊ตํ™˜ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [์ธํ”„๋Ÿฐ ์„น์…˜8] ๋™์ „๊ตํ™˜ (Javascript) ์œ ๋ฃŒ ๊ฐ•์˜์ธ ๊ด€๊ณ„๋กœ ๋ฌธ์ œ ์„ค๋ช…์€ ์ƒ๋žตํ•ฉ๋‹ˆ๋‹ค. โœ๏ธIdea Sketch 2021-06-29 1. ๊ฐ€์žฅ ์ ์€ ์ˆ˜์˜ ๋™์ „์œผ๋กœ ๊ตํ™˜ DP์ธ์ง€ ๊ทธ๋ฆฌ๋””์ธ์ง€ ํ—ท๊ฐˆ๋ฆผ 2. DFS ์ข…๋ฃŒ์กฐ๊ฑด ์ค‘๋ณต์ˆœ์—ด๋กœ ๊ตฌํ˜„ (for ๋ฐ˜๋ณต๋ฌธ) ๊ฑฐ์Šค๋ฆ„๋ˆ์ด target๋ณด๋‹ค ํฌ๊ฑฐ๋‚˜ ๊ฐ™์œผ๋ฉด ์ข…๋ฃŒ --> Math.min()์„ ์จ์•ผํ•˜๋‚˜? ๊ฑฐ์Šค๋ฆ„๋ˆ์ด target๊ณผ ๊ฐ™์€ ๊ฒฝ์šฐ, ๋™์ „์„ ๋ฝ‘์€ ํšŸ์ˆ˜์ธ v๋ฅผ ์ถœ๋ ฅ if (sum >= target) { if (sum === target) console.log(v); return; } 3. DFS ๋กœ์ง ์ค‘๋ณต๊ฐ€๋Šฅ์ด๋ฏ€๋กœ, v๋Š” ๋ฝ‘์€ ์ˆซ์ž๊ฐ€ ์•„๋‹ˆ๋ผ ๋ฝ‘์€ ํšŸ์ˆ˜ for ๋ฐ˜๋ณต๋ฌธ ์‚ฌ์šฉ for (let i=0; i= target) { if (sum === tar..

[์ธํ”„๋Ÿฐ ์„น์…˜8] ์ค‘๋ณต์ˆœ์—ด ๊ตฌํ•˜๊ธฐ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [์ธํ”„๋Ÿฐ ์„น์…˜8] ์ค‘๋ณต์ˆœ์—ด ๊ตฌํ•˜๊ธฐ (Javascript) ์œ ๋ฃŒ ๊ฐ•์˜์ธ ๊ด€๊ณ„๋กœ ๋ฌธ์ œ ์„ค๋ช…์€ ์ƒ๋žตํ•ฉ๋‹ˆ๋‹ค. โœ๏ธIdea Sketch 2021-06-29 1. 1๋ถ€ํ„ฐ N๊นŒ์ง€ ์ˆซ์ž ์ค‘ M๋ฒˆ์„ ๋ฝ‘๊ธฐ ์ค‘๋ณตํ—ˆ์šฉ : ๋ฝ‘์•˜๋˜ ์ˆซ์ž๋ฅผ ๋˜ ๋ฝ‘์Œ ๋‹ค ๋ฝ‘์œผ๋ฉด cnt++ 2. DFS ์ข…๋ฃŒ์กฐ๊ฑด m์ด ๊ธฐ์ค€ DFS์˜ ๋งค๊ฐœ๋ณ€์ˆ˜ v : ์ˆซ์ž๋ฝ‘์€ ํšŸ์ˆ˜ if (v > m) { cnt++; console.log(res); return; } 3. ๋ฝ‘์•˜๋˜ ์ˆซ์ž๋ฅผ ๋˜ ๋ฝ‘๋Š” ๋กœ์ง ์ง€๊ธˆ๊นŒ์ง€๋Š” ๋ฝ‘์€ ๊ฒฝ์šฐ/์•ˆ๋ฝ‘์€ ๊ฒฝ์šฐ ๋‘ ๊ฐ€์ง€๋กœ๋งŒ ํŒŒ์ต ์ง€๊ธˆ์€ ์ˆœ์„œ๋Œ€๋กœ ํ•˜๋‚˜์”ฉ ๋ฝ‘์•„์•ผ ํ•จ --> for ๋ฐ˜๋ณต๋ฌธ? for (let i=1; i m) { cnt++; console.log(res.join(' ')); return; } for (let i = 1; i

[์ธํ”„๋Ÿฐ ์„น์…˜8] ์ตœ๋Œ€์ ์ˆ˜ ๊ตฌํ•˜๊ธฐ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [์ธํ”„๋Ÿฐ ์„น์…˜8] ์ตœ๋Œ€์ ์ˆ˜ ๊ตฌํ•˜๊ธฐ (Javascript) ์œ ๋ฃŒ ๊ฐ•์˜์ธ ๊ด€๊ณ„๋กœ ๋ฌธ์ œ ์„ค๋ช…์€ ์ƒ๋žตํ•ฉ๋‹ˆ๋‹ค. โœ๏ธIdea Sketch 2021-06-29 1. ์ œํ•œ์‹œ๊ฐ„ ์•ˆ์— ์ตœ๋Œ€ํ•œ ๋งŽ์€ ์ ์ˆ˜๋ฅผ ์–ป๊ธฐ 2. DFS ์ข…๋ฃŒ์กฐ๊ฑด if (n >= score.length) { if (totalTime < limitTime) max = Math.max(max, totalScore); return; } 3. DFS ๋‚ด๋ถ€๋กœ์ง totalScore += score[n]; totalTime += time[n]; DFS(n+1); totalScore -= score[n]; totalTime -= time[n]; DFS(n+1); โœ๏ธ์†Œ์Šค์ฝ”๋“œ 2021-06-29 let score = [10, 25, 15, 6, 7]; l..

[์ธํ”„๋Ÿฐ ์„น์…˜8] ๋ฐ”๋‘‘์ด ์Šน์ฐจ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [์ธํ”„๋Ÿฐ ์„น์…˜8] ๋ฐ”๋‘‘์ด ์Šน์ฐจ (Javascript) ์œ ๋ฃŒ ๊ฐ•์˜์ธ ๊ด€๊ณ„๋กœ ๋ฌธ์ œ ์„ค๋ช…์€ ์ƒ๋žตํ•ฉ๋‹ˆ๋‹ค. โœ๏ธIdea Sketch 2021-06-29 1. C๋ฅผ ๋„˜์ง€ ์•Š์œผ๋ฉด์„œ ๊ฐ€์žฅ ๋ฌด๊ฒ๊ฒŒ ์‹ฃ๊ธฐ 2. DFS ์ข…๋ฃŒ์กฐ๊ฑด if (n >= arr.length) { if (sum = arr.length) { if (sum

[์ธํ”„๋Ÿฐ ์„น์…˜8] ํ•ฉ์ด ๊ฐ™์€ ๋ถ€๋ถ„์ง‘ํ•ฉ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [์ธํ”„๋Ÿฐ ์„น์…˜8] ํ•ฉ์ด ๊ฐ™์€ ๋ถ€๋ถ„์ง‘ํ•ฉ (Javascript) ์œ ๋ฃŒ ๊ฐ•์˜์ธ ๊ด€๊ณ„๋กœ ๋ฌธ์ œ ์„ค๋ช…์€ ์ƒ๋žตํ•ฉ๋‹ˆ๋‹ค. โœ๏ธIdea Sketch 2021-06-29 1. (์ง‘ํ•ฉ์˜ ํ•ฉ === ์ „์ฒด ์ง‘ํ•ฉ์˜ ํ•ฉ - ์ง‘ํ•ฉ์˜ ํ•ฉ) ์ธ์ง€ ํ™•์ธํ•˜์—ฌ true๋ฉด "YES", false๋ฉด "NO" ํ•œ ๋ฒˆ์ด๋ผ๋„ ์กฐ๊ฑด์„ ๋งŒ์กฑํ•˜๋ฉด ์ „์ฒด์ข…๋ฃŒ if (n >= arr.length) { let sum = res.reduce((a, b) => a + b, 0); if (su) } 2. ๋ถ€๋ถ„์ง‘ํ•ฉ์˜ ํ•ฉ ๊ตฌํ•˜๋Š” 2๊ฐ€์ง€ ๋ฐฉ๋ฒ• ๋ฐฉ๋ฒ• 1. res.push(), res.pop() let res = []; let total = arr.reduce((a, b) => a + b, 0); function DFS(n) { if (n >= arr.lengt..

[์ธํ”„๋Ÿฐ ์„น์…˜8] ๋ถ€๋ถ„์ง‘ํ•ฉ ๊ตฌํ•˜๊ธฐ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [์ธํ”„๋Ÿฐ ์„น์…˜8] ๋ถ€๋ถ„์ง‘ํ•ฉ ๊ตฌํ•˜๊ธฐ (Javascript) ์œ ๋ฃŒ ๊ฐ•์˜์ธ ๊ด€๊ณ„๋กœ ๋ฌธ์ œ ์„ค๋ช…์€ ์ƒ๋žตํ•ฉ๋‹ˆ๋‹ค. โœ๏ธIdea Sketch 2021-06-29 1. ์ข…๋ฃŒ์กฐ๊ฑด if (n > 3) return; 2. DFS(n+1); ํ˜ธ์ถœ 3. res.push()๋กœ ๊ตฌํ˜„ 4. ์ถœ๋ ฅ์€ ์–ธ์ œ? --> ์ข…๋ฃŒ์กฐ๊ฑด์— ํฌํ•จ 5. n์„ ํฌํ•จํ•˜๊ณ  ๋‚˜์„œ n์„ ํฌํ•จํ•˜์ง€ ์•Š์€ ๊ฒฝ์šฐ์˜ ์ˆ˜ โœ๏ธ์†Œ์Šค์ฝ”๋“œ 2021-06-29 let res = []; function DFS(n) { if (n > 3) { if (res.length > 0) return; } res.push(n); DFS(n + 1); res.pop(); DFS(n + 1); } DFS(1); console.log(res.join(' '))

[์ธํ”„๋Ÿฐ ์„น์…˜8] ์ด์ง„ํŠธ๋ฆฌ ์ˆœํšŒ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [์ธํ”„๋Ÿฐ ์„น์…˜8] ์ด์ง„ํŠธ๋ฆฌ ์ˆœํšŒ (Javascript) ์œ ๋ฃŒ ๊ฐ•์˜์ธ ๊ด€๊ณ„๋กœ ๋ฌธ์ œ ์„ค๋ช…์€ ์ƒ๋žตํ•ฉ๋‹ˆ๋‹ค. โœ๏ธIdea Sketch 2021-06-28 1. ์ด์ง„ํŠธ๋ฆฌ ์ˆœํšŒ ์ „์œ„์ˆœํšŒ : root - ์ขŒ์ธก ํ•˜์œ„๋…ธ๋“œ - ์šฐ์ธก ํ•˜์œ„๋…ธ๋“œ ์ค‘์œ„์ˆœํšŒ : ์ขŒ์ธก ํ•˜์œ„๋…ธ๋“œ - root - ์šฐ์ธก ํ•˜์œ„๋…ธ๋“œ ํ›„์œ„์ˆœํšŒ : ์ขŒ์ธก ํ•˜์œ„๋…ธ๋“œ - ์šฐ์ธก ํ•˜์œ„๋…ธ๋“œ - root โœ๏ธ์†Œ์Šค์ฝ”๋“œ 2021-06-28 ์ „์œ„์ˆœํšŒ let res = ''; function DFS(n) { if (n >= 8) return; res += n + ''; DFS(n * 2); DFS(n * 2 + 1); } DFS(1); console.log(res); 2021-06-28 ์ค‘์œ„์ˆœํšŒ let res = ''; function DFS(n) { if (n >..

[์ธํ”„๋Ÿฐ ์„น์…˜8] ์žฌ๊ท€ํ•จ์ˆ˜๋ฅผ ์ด์šฉํ•œ ์ด์ง„์ˆ˜ ์ถœ๋ ฅ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [์ธํ”„๋Ÿฐ ์„น์…˜8] ์žฌ๊ท€ํ•จ์ˆ˜๋ฅผ ์ด์šฉํ•œ ์ด์ง„์ˆ˜ ์ถœ๋ ฅ (Javascript) ์œ ๋ฃŒ ๊ฐ•์˜์ธ ๊ด€๊ณ„๋กœ ๋ฌธ์ œ ์„ค๋ช…์€ ์ƒ๋žตํ•ฉ๋‹ˆ๋‹ค. โœ๏ธIdea Sketch 2021-06-28 1. 10์ง„์ˆ˜๋ฅผ 2์ง„์ˆ˜๋กœ ์ถœ๋ ฅ 2. (n%2) ์˜ ๊ฒฐ๊ณผ๋ฅผ res.push() 3. n = Math.floor(n/2); 4. res.reverse().join(' '); 5. DFS() ์žฌ๊ท€ํ•จ์ˆ˜ ๊ตฌ์„ฑ ์ข…๋ฃŒ์กฐ๊ฑด DFS() ์žฌ๊ท€ํ˜ธ์ถœ ๋‚ด๋ถ€๋กœ์ง 6. ์ˆซ์ž๋ฅผ ๋ฌธ์ž์—ด๋กœ ์ „ํ™˜ํ•˜๋Š” ๋ฐฉ๋ฒ• 2๊ฐ€์ง€ ๋ฐฉ๋ฒ• 1. String(num); ๋ฐฉ๋ฒ• 2. num + ''; โœ๏ธ์†Œ์Šค์ฝ”๋“œ 2021-06-28 ๋‚ด๋ถ€๋กœ์ง ์‹คํ–‰ ํ›„ DFS() ์žฌ๊ท€ํ˜ธ์ถœ ์—ญ์ˆœ์œผ๋กœ ์ถœ๋ ฅํ•˜๊ธฐ ์œ„ํ•ด arr.reverse() ์‚ฌ์šฉ let res = []; function DFS(n) { if (n ..

[์ธํ”„๋Ÿฐ ์„น์…˜8] ์žฌ๊ท€ํ•จ์ˆ˜ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [์ธํ”„๋Ÿฐ ์„น์…˜8] ์žฌ๊ท€ํ•จ์ˆ˜ (Javascript) ์œ ๋ฃŒ ๊ฐ•์˜์ธ ๊ด€๊ณ„๋กœ ๋ฌธ์ œ ์„ค๋ช…์€ ์ƒ๋žตํ•ฉ๋‹ˆ๋‹ค. โœ๏ธIdea Sketch 2021-06-28 1. ํ•จ์ˆ˜ ์•ˆ์— ํ•จ์ˆ˜๊ฐ€ ์žˆ๋Š” ๊ตฌ์กฐ ์ง€์–‘ 2. res.push(); ํ›„ res.join(' ');์œผ๋กœ ์ถœ๋ ฅ โœ๏ธ์†Œ์Šค์ฝ”๋“œ 2021-06-28 let res = []; function DFS(n) { if (n > 1) DFS(n - 1); res.push(n); } DFS(3); console.log(res.join(' '));

[์ธํ”„๋Ÿฐ ์„น์…˜7] ๋งˆ๊ตฌ๊ฐ„ ์ •ํ•˜๊ธฐ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [์ธํ”„๋Ÿฐ ์„น์…˜7] ๋งˆ๊ตฌ๊ฐ„ ์ •ํ•˜๊ธฐ (Javascript) ์œ ๋ฃŒ ๊ฐ•์˜์ธ ๊ด€๊ณ„๋กœ ๋ฌธ์ œ ์„ค๋ช…์€ ์ƒ๋žตํ•ฉ๋‹ˆ๋‹ค. โœ๏ธIdea Sketch 2021-06-28 1. ์ธ์ ‘ํ•œ ๋ง ์‚ฌ์ด์˜ ๊ฑฐ๋ฆฌ๊ฐ€ ์ตœ๋Œ€๊ฐ€ ๋˜๋„๋ก, ๊ฐ€์žฅ ๊ฐ€๊นŒ์šด ๋‘ ๋ง์˜ ์ตœ๋Œ€๊ฑฐ๋ฆฌ 3๋งˆ๋ฆฌ ๋ง์„ ๋ฐฐ์น˜ 1, 4, 9๋กœ ๋ฐฐ์น˜ํ•  ๊ฒฝ์šฐ ์ธ์ ‘ํ•œ ๋ง ์‚ฌ์ด์˜ ๊ฑฐ๋ฆฌ๊ฐ€ ์ตœ๋Œ€ ๊ฐ€์žฅ ๊ฐ€๊นŒ์šด ๋‘ ๋ง์˜ ์ตœ๋Œ€๊ฑฐ๋ฆฌ๋Š” 4-1 = 3 2. ๋‘ ๋ง์˜ ์ตœ๋Œ€๊ฑฐ๋ฆฌ๋ฅผ ๊ตฌํ•ด์•ผ ํ•˜๋ฏ€๋กœ ๋‘ ๋ง ์‚ฌ์ด์˜ ๋ชจ๋“  ์ข…๋ฅ˜์˜ ๊ฑฐ๋ฆฌ์ •๋ณด๋ฅผ ๋ฐ”ํƒ•์œผ๋กœ, ์ด๋ถ„๊ฒ€์ƒ‰ left, right๋Š” ๋ณด๋‹ค ๋‹จ์ˆœํ•˜๊ฒŒ ๊ตฌํ˜„ ๋‘ ๋ง ์‚ฌ์ด์˜ ์ตœ์†Œ๊ฑฐ๋ฆฌ๋ฅผ mid๋ผ ํ–ˆ์„ ๋•Œ, ๋งˆ๊ตฌ๊ฐ„์— ๋„ฃ์„ ์ˆ˜ ์žˆ๋Š” ๋ง์€ ์ด ๋ช‡๋งˆ๋ฆฌ์ธ์ง€ ํ™•์ธ let left = Math.min(...arr), right = Math.max(...arr); while (left..