Skip to content

Conversation

@yulrang
Copy link
Collaborator

@yulrang yulrang commented Jan 19, 2025

๐Ÿ“Œ ํ‘ผ ๋ฌธ์ œ

์ˆœ์„œ์Œ์˜ ๊ฐœ์ˆ˜ | https://school.programmers.co.kr/learn/courses/30/lessons/120836
์ ์˜ ์œ„์น˜ ๊ตฌํ•˜๊ธฐ | https://school.programmers.co.kr/learn/courses/30/lessons/120841
๋กœ๊ทธ์ธ ์„ฑ๊ณต? | https://school.programmers.co.kr/learn/courses/30/lessons/120883
ํŠน์ดํ•œ ์ •๋ ฌ | https://school.programmers.co.kr/learn/courses/30/lessons/120880

์นด๋“œ ๋ญ‰์น˜ | https://school.programmers.co.kr/learn/courses/30/lessons/159994
๊ณต์› ์‚ฐ์ฑ… | https://school.programmers.co.kr/learn/courses/30/lessons/172928
ํ–„๋ฒ„๊ฑฐ ๋งŒ๋“ค๊ธฐ | https://school.programmers.co.kr/learn/courses/30/lessons/133502

๐Ÿ“ ๊ฐ„๋‹จํ•œ ํ’€์ด ๊ณผ์ •

์นด๋“œ ๋ญ‰์น˜

  • ๊ฐ„๋‹จํ•œ ๋ฌธ์ œ์ ‘๊ทผ๋ฒ•/ํ’€์ด ์„ค๋ช…
    ์นด๋“œ ๋”๋ฏธ์˜ ์ฒซ๋ฒˆ์งธ ๊ฐ’๊ณผ ๋ชฉํ‘œ๊ฐ’ ์ „์ฒด๋ฅผ ๋น„๊ตํ•ฉ๋‹ˆ๋‹ค.
    ์ผ์น˜ํ•  ๊ฒฝ์šฐ ์นด๋“œ ๋”๋ฏธ์˜ ์ฒซ๋ฒˆ์งธ ๊ฐ’์„ ๊บผ๋‚ด๊ณ , ์ผ์น˜ํ•˜๋Š” ์นด๋“œ๊ฐ€ ๋‘ ๋”๋ฏธ ๋ชจ๋‘์— ์—†์„ ๊ฒฝ์šฐ ์ข…๋ฃŒํ•ฉ๋‹ˆ๋‹ค.
function solution(cards1, cards2, goal) {
  var answer = '';
  
  for(let i=0; i<goal.length; i++) {
      if(cards1[0] === goal[i] || cards2[0] === goal[i]){
          if(cards1[0] === goal[i]){
              cards1.shift();
          }
          if(cards2[0] === goal[i]){
              cards2.shift();
          }
          answer = "Yes";
      } else {
          answer = "No";
          break;
      }
  }
  
  return answer;
}

๊ณต์› ์‚ฐ์ฑ…

  • ๊ฐ„๋‹จํ•œ ๋ฌธ์ œ์ ‘๊ทผ๋ฒ•/ํ’€์ด ์„ค๋ช…

pathArr๋Š” ๊ฑธ์–ด๊ฐ„ ์ขŒํ‘œ๋ฅผ ์ €์žฅํ•˜๋Š” ๋ฐฐ์—ด์ž…๋‹ˆ๋‹ค.
์ฒซ๋ฒˆ์งธ ๋ฐ˜๋ณต๋ฌธ์—์„œ๋Š” S๋ฅผ ์ฐพ์•„ pathArr์˜ ์ฒซ๋ฒˆ์งธ ์š”์†Œ๋กœ ์ง‘์–ด๋„ฃ์Šต๋‹ˆ๋‹ค.
๋‘๋ฒˆ์งธ ๋ฐ˜๋ณต๋ฌธ์—์„œ๋Š” ๋ฃจํŠธ์— ๋”ฐ๋ผ ๊ฑธ์Œ์„ ์ˆ˜ํ–‰ํ•ฉ๋‹ˆ๋‹ค.

๊ฑธ์–ด๊ฐ€๋Š” ๋ฐฉํ–ฅ์— ๋”ฐ๋ผ ์ œ์ผ ์ฒซ๋ฒˆ์งธ ๋งˆ์ฃผ์น  ์ˆ˜ ์žˆ๋Š” ๋ธ”๋Ÿญ์˜ ํฌ์ง€์…˜์„ ์ฐพ์•„ ์ €์žฅํ•˜๊ณ ,
๊ฑธ์Œ์„ ์ˆ˜ํ–‰ํ•˜๋ คํ–ˆ์„ ๋•Œ ๋ธ”๋Ÿญ๊ณผ ์ถฉ๋Œํ•œ๋‹ค๋ฉด ๋‹ค์Œ ๋ฃจํŠธ๋กœ ๋„˜์–ด๊ฐ‘๋‹ˆ๋‹ค.

๋ฌธ์ œ๊ฐ€ ์—†์„ ๊ฒฝ์šฐ pathArr์— ์ขŒํ‘œ๋ฅผ ์ €์žฅํ•˜๊ณ  ๊ฑธ์Œ์„ ์ˆ˜ํ–‰ํ•ฉ๋‹ˆ๋‹ค.

function solution(park, routes) {
  let pathArr = [];
  const WIDTH = park[0].length;
  const HEIGHT = park.length;
  
  for(let rowIdx = 0; rowIdx < park.length; rowIdx++){
      const row = park[rowIdx].split("");
      if(row.includes("S")){
          const columnIdx = park[rowIdx].indexOf("S");
          pathArr.push([columnIdx, rowIdx]);
          break;
      }
  }
  
  
  for(let i = 0; i<routes.length; i++) {
      const DIRECTION = routes[i].split(' ')[0];
      const AMOUNT = Number(routes[i].split(' ')[1]);
      let blockPos = [-1, -1];
      let x = pathArr[pathArr.length-1][0];
      let y = pathArr[pathArr.length-1][1];
      
      if (DIRECTION === "E") {
          blockPos = [park[y].indexOf("X", x), y];
          x = pathArr[pathArr.length-1][0] + AMOUNT;
          y = pathArr[pathArr.length-1][1];
      } else if (DIRECTION === "W"){
          blockPos = [park[y].lastIndexOf("X", x), y];
          x = pathArr[pathArr.length-1][0] - AMOUNT;
          y = pathArr[pathArr.length-1][1];
      } else if (DIRECTION === "S"){
          blockPos = [x, park.findIndex((row, idx) => idx >= y && row[x] === "X")];
          x = pathArr[pathArr.length-1][0];
          y = pathArr[pathArr.length-1][1] + AMOUNT;
      } else if (DIRECTION === "N"){
          blockPos = [x, park.slice(0, y).reverse().findIndex((row, idx) => row[x] === "X")];
          if (blockPos[1] !== -1) blockPos[1] = y - blockPos[1] - 1;
          x = pathArr[pathArr.length-1][0];
          y = pathArr[pathArr.length-1][1] - AMOUNT;
      }
  
      if (x < 0 || x >= WIDTH || y < 0 || y >= HEIGHT){
          continue;
      }
      if(!blockPos.includes(-1)){
          if((y === blockPos[1] && x >= blockPos[0] && pathArr[pathArr.length > 1 ? pathArr.length-2 : 0][0] < blockPos[0]) || 
             (y === blockPos[1] && x <= blockPos[0] && pathArr[pathArr.length > 1 ? pathArr.length-2 : 0][0] > blockPos[0]) ||
             (x === blockPos[0] && y >= blockPos[1] && pathArr[pathArr.length > 1 ? pathArr.length-2 : 0][1] < blockPos[1]) ||
              (x === blockPos[0] && y <= blockPos[1] && pathArr[pathArr.length > 1 ? pathArr.length-2 : 0][1] > blockPos[1]) ) {
              continue;
          }
      }
      
      pathArr.push([x, y]);
  }
  
  return pathArr[pathArr.length-1].reverse();
}


ํ–„๋ฒ„๊ฑฐ ๋งŒ๋“ค๊ธฐ

  • ๊ฐ„๋‹จํ•œ ๋ฌธ์ œ์ ‘๊ทผ๋ฒ•/ํ’€์ด ์„ค๋ช…
    ์žฌ๋ฃŒ๋ฐฐ์—ด์ด [1,2,3,1]์˜ ๋ฐฐ์—ด์„ ๊ฐ€์งˆ ๋•Œ ํ•ด๋‹น ๋ฐฐ์—ด์„ ์‚ญ์ œํ•˜๊ณ , ๋งŒ๋“  ํ–„๋ฒ„๊ฑฐ์˜ ๊ฐœ์ˆ˜๋ฅผ ์ฆ๊ฐ€์‹œํ‚ต๋‹ˆ๋‹ค.
    4๊ฐœ์˜ ์š”์†Œ๋ฅผ ํƒ์ƒ‰ํ–ˆ์œผ๋ฏ€๋กœ ์ธ๋ฑ์Šค๋Š” 4๋งŒํผ๋งŒ ์‚ญ์ œ์‹œํ‚ค๊ณ  ๋‹ค์‹œ ๊ฒ€์ƒ‰ํ•ฉ๋‹ˆ๋‹ค.
function solution(ingredient) {
  var answer = 0;
  
  for(let i=0; i<ingredient.length; i++) {
      if(ingredient[i] === 1 && ingredient[i+1] === 2 && ingredient[i+2] === 3 && ingredient[i+3] === 1) {
          ingredient.splice(i, 4);
          answer++;
          i -= 4;
      }
  }
  return answer;
}

@yulrang yulrang self-assigned this Jan 19, 2025
Copy link
Collaborator

@JooKangsan JooKangsan left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

์ˆ˜๊ณ ํ•˜์…จ์–ด์š”!! ๋‹ค์Œ์ฃผ๋„ ํ™”์•„ํŒ…์ž…๋‹ˆ๋‹ค!

@JooKangsan JooKangsan merged commit cf0bad6 into main Jan 23, 2025
3 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants