๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ 130

[๋ฐฑ์ค€ 1697] ์ˆจ๋ฐ”๊ผญ์งˆ (Python)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [๋ฐฑ์ค€ 1697] ์ˆจ๋ฐ”๊ผญ์งˆ (Python) โœ๏ธIdea Sketch 2021-07-28 1. ์  N์˜ ๋ฒ”์œ„ (0 ≤ N ≤ 100,000) visited๋Š” ํฌ๊ธฐ๊ฐ€ 100001์ธ ๋ฐฐ์—ด visited = [0]*100001 # ๋ฐฉ๋ฒ•1 visited = [0 for i in range(100001)] # ๋ฐฉ๋ฒ•2 2. ์†Œ์š” ์‹œ๊ฐ„ ์นด์šดํŠธํ•˜๋Š” ๋ฐฉ๋ฒ• visited[i] = visited[v] + 1 3. ์  N ๋ฐฉ๋ฌธ์ฒ˜๋ฆฌํ•  ํ•„์š” ์—†์Œ N์„ ๋‹ค์‹œ ๋ฐฉ๋ฌธํ•˜๋Š” ๊ฒฝ๋กœ๋Š” ์–ด์ฐจํ”ผ ์ตœ๋‹จ๊ฒฝ๋กœ๊ฐ€ ์•„๋‹˜ def bfs(N, K, visited): queue = deque([N]) visited[N] = 1 # ๋ถˆํ•„์š” โœ๏ธ์†Œ์Šค์ฝ”๋“œ 2021-07-28 156ms ํ†ต๊ณผ import sys from collections impor..

[๋ฐฑ์ค€ 1260] DFS์™€ BFS (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [๋ฐฑ์ค€ 1260] DFS์™€ BFS (Javascript)) โœ๏ธIdea Sketch 2021-07-30 1. ๋ฐฑ์ค€ ์ž…๋ ฅ๊ฐ’ ๋ฐ›๊ธฐ const fs = require('fs'); const stdin = (process.platform === 'linux' ? fs.readFileSync('/dev/stdin').toString() // ๋ฐฑ์ค€์— ์ฝ”๋“œ ์ œ์ถœํ–ˆ์„ ๋•Œ : `5 5 3 5 4 5 2 1 2 3 4 3 1` // IDE์—์„œ ์‹คํ–‰ํ•  ๋•Œ ).split('\n'); 2. ์–‘๋ฐฉํ–ฅ ๊ทธ๋ž˜ํ”„ ์ •์˜ํ•˜๊ธฐ let graph = Array.from({ length: n + 1 }, (v) => (Array.from({ length: n + 1 }, v => 0))); for (let i = 1; i (Ar..

[๋ฐฑ์ค€ 2003] ์ˆ˜๋“ค์˜ ํ•ฉ 2 (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [๋ฐฑ์ค€ 2003] ์ˆ˜๋“ค์˜ ํ•ฉ 2 (Javascript) โœ๏ธIdea Sketch 2021-07-19 1. ๋ฌธ์ œ ์ดํ•ด ์—ฐ์†ํ•œ ์ˆ˜๋“ค์˜ ํ•ฉ์ด M์„ ๋„˜๋Š” ๊ฒฝ์šฐ์˜ ์ˆ˜ ๊ตฌํ•˜๊ธฐ 2. ๋ฐฑ์ค€ javascript ์ž…๋ ฅ๋ฐ›๊ธฐ const fs = require('fs'); const stdin = (process.platform === 'linux' ? fs.readFileSync('/dev/stdin').toString() : `10 5 1 2 3 4 2 5 3 1 1 2` ).split('\n'); let [N, M] = stdin[0].split(' ').map(Number); let input = stdin[1].split(' ').map(Number); 3. ๋กœ์ง left, right ์Šฌ๋ผ์ด๋”ฉ ์œˆ๋„์šฐ ..

[๋ฐฑ์ค€ 2805] ๋‚˜๋ฌด ์ž๋ฅด๊ธฐ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [๋ฐฑ์ค€ 2805] ๋‚˜๋ฌด ์ž๋ฅด๊ธฐ (Javascript) โœ๏ธIdea Sketch 2021-07-19 1. ๋กœ์ง : ์ด๋ถ„ ํƒ์ƒ‰ input ์ •๋ ฌ ์ ˆ๋‹จ๊ธฐ์— ์„ค์ •ํ•  ์ˆ˜ ์žˆ๋Š” ๋†’์ด์˜ ์ตœ์†Ÿ๊ฐ’ : left = 0; ์ตœ๋Œ“๊ฐ’ : right = input[input.length-1]; // ๋งˆ์ง€๋ง‰ ์›์†Œ์ด์ž ๊ฐ€์žฅ ํฐ ์›์†Œ mid๋กœ ์ ˆ๋‹จ๊ธฐ ์„ค์ •ํ–ˆ์„ ๋•Œ, ๋ช‡๋ฏธํ„ฐ์˜ ๋‚˜๋ฌด๋ฅผ ๊ฐ€์ ธ๊ฐˆ ์ˆ˜ ์žˆ๋Š”์ง€ ํ™•์ธํ•˜๋Š” ํ•จ์ˆ˜ ๋‚˜๋ฌด๊ฐ€ ๋„‰๋„‰ํ•  ๊ฒฝ์šฐ, right = mid-1; ๋‚˜๋ฌด๊ฐ€ ๋ถ€์กฑํ•  ๊ฒฝ์šฐ, left = mid+1; 2. mid๋งŒํผ ๋‚˜๋ฌด๋ฅผ ์ ˆ๋‹จํ•œ๋‹ค ๊ฐ€์ •ํ–ˆ์„ ๋•Œ, ์ƒ๊ทผ์ด๊ฐ€ ๊ฐ€์ ธ๊ฐ€๋Š” ๋‚˜๋ฌด ๊ธธ์ด๋ฅผ ๊ตฌํ•˜๋Š” ํ•จ์ˆ˜ ๊ฐ€์ ธ๊ฐˆ ์ˆ˜ ์žˆ๋Š” ๋‚˜๋ฌด ๊ธธ์ด > ์ฑ™๊ธธ ๋‚˜๋ฌด ๊ธธ์ด --> ๋†’์ด๋ฅผ ๋†’์—ฌ์•ผ์ง€ --> left = mid+1; ๊ฐ€์ ธ๊ฐˆ ์ˆ˜ ์žˆ๋Š” ๋‚˜๋ฌด ๊ธธ์ด <..

[๋ฐฑ์ค€ 2816] ๋””์ง€ํ„ธ ํ‹ฐ๋น„ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [๋ฐฑ์ค€ 2816] ๋””์ง€ํ„ธ ํ‹ฐ๋น„ (Javascript) โœ๏ธIdea Sketch 2021-07-19 1. KBS1, KBS2์˜ ์œ„์น˜๋ฅผ ์•Œ์•„์•ผ ํ•จ 2. KBS1์˜ ์œ„์น˜๊ฐ€ 1์ด๋ผ๋ฉด, 1ํ•˜๊ณ  4 3. 1๊ณผ 4๋กœ๋„ ์ถฉ๋ถ„ํžˆ ํ•  ์ˆ˜ ์žˆ์ง€ ์•Š๋‹ˆ?? โœ๏ธ์†Œ์Šค์ฝ”๋“œ 2021-07-19 ํ†ต๊ณผ, 112ms let fs = require('fs'); let input = fs.readFileSync('/dev/stdin').toString().split('\n'); let N = parseInt(input.shift()); let index1 = input.indexOf('KBS1'); let index2 = input.indexOf('KBS2'); index2 = index1>index2 ? ++index2 :..

[๋ฐฑ์ค€ 1110] ๋”ํ•˜๊ธฐ ์‚ฌ์ดํด (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [๋ฐฑ์ค€ 1110] ๋”ํ•˜๊ธฐ ์‚ฌ์ดํด (Javascript) โœ๏ธIdea Sketch 2021-07-19 1. ๋ฌธ์ œ ์ดํ•ด 26, 2+6 = 8, 68, 6+8 = 14, 84, 8+4 = 12, 42, 4+2 = 6, 26 2. ์‹ญ์˜ ์ž๋ฆฌ ์ˆ˜์™€ ์ผ์˜ ์ž๋ฆฌ ์ˆ˜ ๋”ํ•˜๊ธฐ let num = 26; let sum = parseInt(num%10 + num/10); console.log(sum); 3. ๋”ํ•˜๊ธฐ ์ „ ์ˆ˜๋ฅผ ์ €์žฅํ•ด๋†”์•ผ ํ•จ 4. ๋”ํ•˜๊ธฐ ์ „ ์ผ์˜ ์ž๋ฆฌ์™€ (์‹ญ์˜ ์ž๋ฆฌ๋กœ ๋งŒ๋“ค์–ด์•ผ ํ•จ), ๋”ํ•œ ํ›„ ์ผ์˜ ์ž๋ฆฌ์™€ ํ•ฉ์น˜๊ธฐ num = num%10 + sum%10; 5. ์นด์šดํŠธ ์„ธ๊ธฐ, ๋ฐ˜๋ณต๋ฌธ ์ƒˆ๋กœ์šด ์ˆ˜๊ฐ€ ์ƒ๊ธธ ๋•Œ๋งˆ๋‹ค cnt++; ์ƒˆ๋กœ์šด ์ˆ˜๊ฐ€ ์ƒ๊ธธ ๋•Œ๋งˆ๋‹ค ์›๋ž˜ ์ˆ˜์™€ ์ผ์น˜ํ•˜๋Š”์ง€ ํ™•์ธ let num = N; let ..

[๋ฐฑ์ค€ 1652] ๋ˆ„์šธ ์ž๋ฆฌ๋ฅผ ์ฐพ์•„๋ผ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [๋ฐฑ์ค€ 1652] ๋ˆ„์šธ ์ž๋ฆฌ๋ฅผ ์ฐพ์•„๋ผ (Javascript) โœ๏ธIdea Sketch 2021-07-17 1. ๋กœ์ง ์—ฐ์† 2์นธ ์ด์ƒ์˜ ๋นˆ ์นธ์ด ์กด์žฌํ•˜๋ฉด ๋ˆ•๋Š”๋‹ค. ๋ˆ„์šธ ๋•Œ๋Š” ๋ฌด์กฐ๊ฑด ๋ชธ์„ ์ญ‰ ๋ป—๊ธฐ ๋•Œ๋ฌธ์— ๋ฐ˜๋“œ์‹œ ๋ฒฝ์ด๋‚˜ ์ง์— ๋‹ฟ๋Š”๋‹ค!! 2. ๊ฐ€๋กœ๋กœ ๋ˆ„์šธ ์ˆ˜ ์žˆ๋Š” ์ž๋ฆฌ ๋ฌธ์ž์—ด์„ X๊ธฐ์ค€์œผ๋กœ ๋‚˜๋ˆˆ ํ›„, includes()๋กœ ..์ด ์žˆ๋Š”์ง€ ํ™•์ธ input[i].split('X').forEach(v => { if (v.includes('..')) row++; }) filter() ์‚ฌ์šฉ row += input[i].split('X').filter(v => v.includes('..')).length; 3. ์„ธ๋กœ๋กœ ๋ˆ„์šธ ์ˆ˜ ์žˆ๋Š” ์ž๋ฆฌ .์„ ์นด์šดํŠธ X๊ฐ€ ๋‚˜์˜ค๋ฉด ์ดˆ๊ธฐํ™” 4. 2๊ฐœ ์ด์ƒ์ผ ๋•Œ 1๋ฒˆ๋งŒ ์นด์šดํŠธ ํ•ด์•ผ..

[ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค 43238] ์ž…๊ตญ์‹ฌ์‚ฌ (Javascript) (ํ†ต๊ณผX)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค 43238] ์ž…๊ตญ์‹ฌ์‚ฌ (Javascript) โœ๏ธIdea Sketch 2021-07-13 1. ๋ฌธ์ œ ์ดํ•ด ๋ชจ๋“  ์‚ฌ๋žŒ์ด ์‹ฌ์‚ฌ๋ฅผ ๋ฐ›๋Š”๋ฐ ๊ฑธ๋ฆฌ๋Š” ์‹œ๊ฐ„์˜ ์ตœ์†Ÿ๊ฐ’ (sum) ๊ฐ€์žฅ ์•ž์— ์žˆ๋Š” ์‚ฌ๋žŒ์€ ๋น„์–ด ์žˆ๋Š” ์‹ฌ์‚ฌ๋Œ€๋กœ ๊ฐ€์„œ ์‹ฌ์‚ฌ๋ฅผ ๋ฐ›์„ ์ˆ˜ ๋” ๋นจ๋ฆฌ ๋๋‚˜๋Š” ์‹ฌ์‚ฌ๋Œ€๊ฐ€ ์žˆ์œผ๋ฉด ๊ธฐ๋‹ค๋ ธ๋‹ค๊ฐ€ ์‹ฌ์‚ฌ๋Œ€ ์ด๋™!!! 2. ๋กœ์ง ์‹ฌ์‚ฌ ๋ฐ›๋Š” ๋ฐ์— ๊ฑธ๋ฆฌ๋Š” ์‹œ๊ฐ„ sum ์‹ฌ์‚ฌ๊ฐ€ ๋” ๋นจ๋ฆฌ ๋๋‚˜๋Š” ๊ณณ์— ๋ฐฐ์ •ํ•ด์ค˜์•ผํ•จ --> ์ •๋ ฌ?! times๋ฅผ ์˜ค๋ฆ„์ฐจ์ˆœ์œผ๋กœ ์ •๋ ฌ 3. ๋กœ์ง ์ฐฌ์ฐฌํžˆ ๋œฏ์–ด๋ณด๊ธฐ.. 0๋ช…, 0๋ถ„, [7, 10] --> 2๋ช…, 7๋ถ„, [0, 3] ์‹ฌ์‚ฌ๋Œ€ ์‹œ๊ฐ„ ์ค‘ ๊ฐ€์žฅ ์ž‘์€ ์‹œ๊ฐ„๋งŒํผ ๋นผ์คŒ ([7, 10] ์ค‘์— 7์ด ๊ฐ€์žฅ ์ž‘์œผ๋ฏ€๋กœ ์ „์ฒด -7, sum์€ +7ํ•˜์—ฌ 7๋ถ„) 0๋ถ„์ธ ์‹ฌ์‚ฌ๋Œ€๊ฐ€ ๊ฐ€์žฅ ์ฒซ๋ฒˆ์งธ ์‹ฌ์‚ฌ๋Œ€์ด๋ฏ€๋กœ ๋ฐ”๋กœ..

[ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค 43165] ํƒ€๊ฒŸ ๋„˜๋ฒ„ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค 43165] ํƒ€๊ฒŸ ๋„˜๋ฒ„ (Javascript) โœ๏ธIdea Sketch 2021-07-13 1. ๋ฌธ์ œ ์ดํ•ด ๋”ํ•˜๊ธฐ ๋นผ๊ธฐ ๋‘๊ฐ€์ง€ ์—ฐ์‚ฐ 2. ๋กœ์ง DFS numbers์˜ ์›์†Œ๋ฅผ ๋”ํ•˜๋Š” ๊ฒฝ์šฐ or ๋นผ๋Š” ๊ฒฝ์šฐ 3. DFS ์ข…๋ฃŒ์กฐ๊ฑด : v === numbers.length ์ธ ๊ฒฝ์šฐ sum += numbers[v]; // v๋ฒˆ์งธ ์›์†Œ๋ฅผ ๋”ํ•˜๋Š” ๊ฒฝ์šฐ DFS(v+1); sum -= numbers[v]*2; // v๋ฒˆ์งธ ์›์†Œ๋ฃฐ ๋นผ๋Š” ๊ฒฝ์šฐ DFS(v+1); sum += numbers[v]; // ์›๋ณต โœ๏ธ์†Œ์Šค์ฝ”๋“œ 2021-07-13 ์ •ํ™•์„ฑ ํ†ต๊ณผ function solution(numbers, target) { let cnt = 0; let sum = 0; function DFS(v) { if..

[ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค 42842] ์นดํŽซ (Javascript)

๐Ÿ‘ฉ๐Ÿป‍๐Ÿ’ป๋ฌธ์ œ๋งํฌ [ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค 42842] ์นดํŽซ (Javascript) โœ๏ธIdea Sketch 2021-07-09 1. ๋ฌธ์ œ ์ดํ•ด ํ…Œ๋‘๋ฆฌ 1์ค„์€ ๊ฐˆ์ƒ‰ ๊ฐ€๋กœ ๊ธธ์ด >= ์„ธ๋กœ ๊ธธ์ด 2. ๋กœ์ง ํ•ญ์ƒ ๋งŒ์กฑํ•˜๋Š” ๊ฒƒ : brown/2 +2 === ๊ฐ€๋กœ๊ธธ์ด + ์„ธ๋กœ๊ธธ์ด brown/2 +2๊ฐ’์„ ๊ตฌํ•œ ํ›„, ๊ฐ€๋กœ์„ธ๋กœ ์Œ (sum-i, i) ๋…ธ๋ž€์ƒ‰ ์นดํŽซ์„ ๋ชจ๋‘ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋Š”๊ฐ€? ๋…ธ๋ž€์ƒ‰ ์นดํŽซ์˜ ๊ฐ€๋กœ์„ธ๋กœ ๊ธธ์ด = (์ „์ฒด ์นดํŽซ์˜ ๊ฐ€๋กœ - 2, ์ „์ฒด ์นดํŽซ์˜ ์„ธ๋กœ - 2) ๋…ธ๋ž€์ƒ‰ ์นดํŽซ์˜ ๊ฐ€๋กœ๊ธธ์ด x ์„ธ๋กœ๊ธธ์ด๋ฅผ ๊ตฌํ•˜๋ฉด ๋จ let sum = (brown/2) + 2; for (let i=1; i = 1๊นŒ์ง€ ๋ฐ˜๋ณตํ•˜์ง€ ์•Š์Œ for (let i = sum-1; i >= sum/2; i--) โœ๏ธ์†Œ์Šค์ฝ”๋“œ 2021-07-09 function..