섹션1의 17번문제 이 풀이로 풀어도 될까요?
133
1 asked
<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>
Answer 2
0
안녕하세요^^
네. 잘 하신 코드입니다. 기초를 배우는 섹션이기 때문에 이 문제를 만든 의미는 set 보다는 반복문을 통해서 중복을 직접 걸러내는 훈련을 하기 위해서입니다. 문제를 만든 목적에 충실한 코드입니다.
아래 답변처럼 set으로 중복을 제거하는 것도 알아두셔서 나중 복잡한 문제를 풀 때는 set으로 중복제거를 하세요.
0
안녕하세요, 인프런 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
78
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
141
0
코드 리뷰 부탁드립니다.
0
119
1
코드 맞게 작성한 거 아닌가여??
0
146
1
문드윽뀨
0
98
1

