Java java지도 시간 LeetCode & Q26-정렬된 배열에서 중복 제거-쉬움

LeetCode & Q26-정렬된 배열에서 중복 제거-쉬움

Jul 09, 2017 pm 06:12 PM
leetcode

설명:

정렬된 배열이 주어지면 각 요소가 한 번만만 나타나도록 중복 항목을 제거하고 새 길이를 반환합니다.

다른 배열에 추가 공간을 할당하지 마십시오. 일정한 메모리를 사용하여 이 작업을 수행해야 합니다. 예를 들어

주어진 입력 배열 nums = [1,1,2],[1,1,2],

Your function should return length = 2, with the first two elements of nums being 1 and 2 respectively. It doesn't matter what you leave beyond the new length.

我写的一直有问题...用了HashSet集合,没有研究过这个类型,[1,1,2]输出结果一直是[1,1]

(在小本本上记下,要研究HashSet)

<code class="sourceCode java"><span class="kw">import java.util.HashSet;</span>

<span class="kw">import java.util.Set;</span>

<span class="kw">public</span> <span class="kw">class</span> Solution {

    <span class="kw">public</span> <span class="dt">static</span> <span class="dt">int</span> <span class="fu">removeDuplicates</span>(<span class="dt">int</span>[] nums) {

        Set<Integer> tempSet = <span class="kw">new</span> HashSet<>();

        <span class="kw">for</span>(<span class="dt">int</span> i = <span class="dv">0</span>; i < nums.<span class="fu">length</span>; i++) {

            Integer wrap = Integer.<span class="fu">valueOf</span>(nums[i]);

            tempSet.<span class="fu">add</span>(wrap);

        }

        <span class="kw">return</span> tempSet.<span class="fu">size</span>();

    }

}</code>
로그인 후 복사

下面是优秀答案

Solutions:

<code class="sourceCode java"><span class="kw">public</span> <span class="kw">class</span> Solution {

    <span class="kw">public</span> <span class="dt">static</span> <span class="dt">int</span> <span class="fu">removeDuplicates</span>(<span class="dt">int</span>[] nums) {

        <span class="dt">int</span> j = <span class="dv">0</span>;

        <span class="kw">for</span>(<span class="dt">int</span> i = <span class="dv">0</span>; i < nums.<span class="fu">length</span>; i++) {

            <span class="kw">if</span>(nums[i] != nums[j]) {

                nums[++j] = nums[i];

            }

        }

        <span class="kw">return</span> ++j;

    }

}</code>
로그인 후 복사

有两个点需要注意:

  1. 因为重复的可能有多个,所以不能以相等来做判定条件
  2. 注意j++++j
  3. 함수는 길이 = 2를 반환해야 하며,
nums🎜의 처음 두 요소는 각각 12입니다. 이는 중요하지 않습니다. 새로운 길이 너머로 남겨두는 것.🎜 🎜저는 항상 제가 쓴 내용에 문제가 있었습니다... 저는 HashSet 컬렉션을 사용했고 이 유형을 연구한 적이 없습니다. [1,1,2]의 출력 결과는 항상 [1,1]🎜입니다. 🎜(HashSet 공부에 필요한 내용을 노트에 적어보세요)🎜
rrreee
🎜훌륭한 답변은 다음과 같습니다🎜 🎜솔루션:🎜
rrreee
🎜주의해야 할 두 가지 사항이 있습니다: 🎜
  • 중복이 여러개 있을 수 있으므로 동등을 판단 조건으로 사용할 수 없습니다🎜
  • j++++j의 차이점에 주의하세요. 여기서 사용법은 매우 영리하고 필요합니다! 🎜 🎜
  • 위 내용은 LeetCode & Q26-정렬된 배열에서 중복 제거-쉬움의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    본 웹사이트의 성명
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

    핫 AI 도구

    Undresser.AI Undress

    Undresser.AI Undress

    사실적인 누드 사진을 만들기 위한 AI 기반 앱

    AI Clothes Remover

    AI Clothes Remover

    사진에서 옷을 제거하는 온라인 AI 도구입니다.

    Undress AI Tool

    Undress AI Tool

    무료로 이미지를 벗다

    Clothoff.io

    Clothoff.io

    AI 옷 제거제

    AI Hentai Generator

    AI Hentai Generator

    AI Hentai를 무료로 생성하십시오.

    인기 기사

    R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. 최고의 그래픽 설정
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
    Will R.E.P.O. 크로스 플레이가 있습니까?
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

    뜨거운 도구

    메모장++7.3.1

    메모장++7.3.1

    사용하기 쉬운 무료 코드 편집기

    SublimeText3 중국어 버전

    SublimeText3 중국어 버전

    중국어 버전, 사용하기 매우 쉽습니다.

    스튜디오 13.0.1 보내기

    스튜디오 13.0.1 보내기

    강력한 PHP 통합 개발 환경

    드림위버 CS6

    드림위버 CS6

    시각적 웹 개발 도구

    SublimeText3 Mac 버전

    SublimeText3 Mac 버전

    신 수준의 코드 편집 소프트웨어(SublimeText3)