Leetcode Diary: 고유한 이메일 주소

https://leetcode.com/problems/unique-email-addresses/submissions/

이것은 당신이 leetcode 스타일의 인터뷰를 하지 않았거나 당신이 leetcode를 한 지 오래되었다면 시작하기에 좋은 질문입니다.

특정 문자를 제거하기 위해 이메일 문자열을 처리하는 문제는 다소 간단합니다. 세 가지 규칙을 따라야 합니다.
1.) @ 기호 뒤에 있는 부분은 그대로 둡니다.
2.) + 뒤와 @ 앞 부분은 무시하십시오.
3.) 모든 점 제거
반환 값은 처리 후 얼마나 많은 고유한 이메일이 있는지입니다.

아래는 쉬운 버전의 의사입니다.

pseudo:
emailsSet = new Set()

for each email in emails
parts = email.indexOf("@")
local = parts[0]

noPlus = ignorePlus(local)
noPlusNoDot = removeDots(local)

returnEmail = noPlusNoDot + parts[1]

emailsSet.add(returnEmail)
return eamilsSet.length();


신입사원을 목표로 한다면. 이것은 많은 문제 없이 전체 코드로 구현할 수 있어야 하는 것입니다.

엔트리보다 고급이라면 javascript 내장 함수를 사용하지 않고 substring()을 사용하지 않고 답을 생각하십시오.

생각은 이렇습니다.
Q: 이전 캐릭터를 참조해야 하는 복잡한 규칙이 있나요?
A: 아니오, 알겠습니다. 그럼 루프만 있으면 됩니다.
Q: 어떻게 반복합니까?
A: 캐릭터를 추가하거나 무시하기 위한 조건을 제공합니다.
문: 그게 전부인가요?
A: 음, + 및 @ 조건에 주의해야 합니다. +를 누른 후 @를 누를 때까지 무시합니다.
Q: 조건을 어떻게 주문합니까? 중요합니까?
A: @를 누르면 모든 것을 추가하기 때문에 중요합니다. 조건 주문이 중요한 이유 중 하나입니다.

또한 +를 누르면 문자열에 추가되지 않으므로 문자열에 추가하는 것이 최종 기본 조건이어야 합니다.

이를 염두에 두고 다음과 같은 코드를 작성할 수 있어야 합니다.

var numUniqueEmails = function(emails) {
    const emailsSet = new Set();
    for (let email of emails) {
        let finalString = ''
        let facedPlus = false;

        for (let i=0; i < email.length; i++) {
            const current = email[i];
            if(current === '@') {
                finalString += email.substring(i)
                break;
            } else if (current === ".") {
                continue;
            } else if (current === "+") {
                facedPlus = true;
                continue;
            } else if (facedPlus) {
                continue;
            } else {
                finalString += current;
            }
        }

        emailsSet.add(finalString);
    }

    return emailsSet.size

}


불분명 한 것을 놓친 경우 알려주십시오. 감사합니다!

더 많은 콘텐츠를 보고 싶다면 팔로우를 눌러주세요. 불규칙하지만 다소 자주 업데이트하겠습니다.

이력서나 전반적인 경력 궤적에 대해 저와 1:1 대화를 나누고 싶으시면 https://www.fiverr.com/kevtseng으로 연락해 주세요.

소셜:

좋은 웹페이지 즐겨찾기