inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Giới thiệu về giải quyết vấn đề thuật toán JavaScript (chuẩn bị cho bài kiểm tra mã hóa)

17. Loại bỏ các từ trùng lặp

섹션1의 17번문제 이 풀이로 풀어도 될까요?

133

ran89912658

1 câu hỏi đã được viết

0

<html>
  <head>
    <meta charset="UTF-8" />
    <title>출력결과</title>
  </head>
  <body>
    <script>
      function solution(s) {
        let answer = [];

        for (e of s) {
          if (!answer.includes(e)) {
            answer.push(e);
          }
        }

        return answer;
      }
      let str = ["good", "time", "good", "time", "student"];
      console.log(solution(str));
    </script>
  </body>
</html>

javascript 코딩-테스트

Câu trả lời 2

0

codingcamp

안녕하세요^^

네. 잘 하신 코드입니다. 기초를 배우는 섹션이기 때문에 이 문제를 만든 의미는 set 보다는 반복문을 통해서 중복을 직접 걸러내는 훈련을 하기 위해서입니다. 문제를 만든 목적에 충실한 코드입니다.

아래 답변처럼 set으로 중복을 제거하는 것도 알아두셔서 나중 복잡한 문제를 풀 때는 set으로 중복제거를 하세요.

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. 박경란님.

질문해 주신 코드는 제대로 작동하며 중복된 요소를 제거할 수 있는 실용적인 방법입니다. includes 메소드를 사용하여 배열에 이미 요소가 있는지 확인한 뒤, 중복되지 않는 요소만 push를 통해 추가하는 로직을 사용하였습니다.

다만, 좀 더 간단한 방법으로는 JavaScript의 Set 객체를 사용할 수 있습니다. Set을 사용하면 중복을 자동으로 제거해 주기 때문에 코드가 더 간결해질 수 있습니다. 아래는 Set을 이용한 방법입니다:

function solution(s) {
    return Array.from(new Set(s));
}
let str = ["good", "time", "good", "time", "student"];
console.log(solution(str));

Set에 대해 더 알고 싶다면 유사한 질문과 답변이 있는 Set 이용 페이지를 참고하실 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

continue를 사용하는 이유

0

79

2

정렬 가능 여부 판단하기

0

64

2

알고리즘 학습법 관련해서 질문드립니다.

0

85

1

코드 리뷰 부탁드립니다!

0

90

1

indexOf를 사용해서 풀어보았습니다 !!

0

68

1

저는 이런식으로 구현 해보았습니다 !!

0

64

1

12,13,14 강의 소리만 나오고 검은 화면입니다

0

99

3

반복문 최소화하고 indexOf 사용해서 풀어봤습니다

0

63

1

영상 보기 전에 직접 풀어봤습니다.

0

74

1

정규표현식으로 처리해도 상관없나요 ?

0

120

2

3칸씩 건너뛸 수 있을 경우

0

125

2

강의에 대해 질문있습니다.

0

135

2

Object와 Set을 이용해 풀어봤습니다.

0

117

2

이렇게 해도 되나요?

0

102

2

선생님 중복 단어나 중복관련 문제들은 set을 이용하면 좋을것 같습니다.

0

145

2

이렇게 풀어도 괜찮을까요?

0

138

1

이렇게 풀어도 괜찮을까요?

0

112

1

모든 아나그램 찾기에서 시간복잡도

0

98

1

코드리뷰 부탁드립니다.

0

130

1

for loop 탈출은 return 문으로 해도 되지 않나요?

0

133

1

투포인트알고리즘으로 풀어봤습니다.

0

142

0

코드 리뷰 부탁드립니다.

0

120

1

코드 맞게 작성한 거 아닌가여??

0

146

1

문드윽뀨

0

98

1