목차
문제 설명
임의 스택 생성 및 복제
순진한 접근 방식을 사용하여 특정 스택에서 중복 제거
최적화된 접근 방식(HashSet)을 사용하여 주어진 스택에서 중복 항목을 제거합니다(HashSet)
예시 
비교
Java java지도 시간 주어진 스택에서 중복을 제거하는 Java 프로그램

주어진 스택에서 중복을 제거하는 Java 프로그램

Aug 28, 2024 pm 12:01 PM
java

이 기사에서는 Java의 스택에서 중복 요소를 제거하는 두 가지 방법을 살펴보겠습니다. 중첩 루프를 사용한 간단한 접근 방식과 HashSet을 사용하는 보다 효율적인 방법을 비교해 보겠습니다. 목표는 중복 제거를 최적화하는 방법을 보여주고 각 접근 방식의 성능을 평가하는 것입니다.

문제 설명

스택에서 중복된 요소를 제거하는 Java 프로그램을 작성하세요.

입력

으아아아

출력

으아아아

주어진 스택에서 중복 항목을 제거하려면 2가지 접근 방식이 있습니다. −

  • 순진한 접근 방식: 두 개의 중첩 루프를 만들어 어떤 요소가 이미 존재하는지 확인하고 해당 요소가 결과 스택 반환에 추가되지 않도록 합니다.
  • HashSet 접근 방식: Set을 사용하여 고유한 요소를 저장하고 O(1) 복잡성을 활용하여 요소가 있는지 여부를 확인합니다.

임의 스택 생성 및 복제

아래는 Java 프로그램이 먼저 임의의 스택을 구축한 다음 추가 사용을 위해 복사본을 생성하는 것입니다 −

으아아아

initData 지정된 크기와 1~100 범위의 임의 요소로 스택을 생성하는 데 도움이 됩니다.

manualCloneStack 다른 스택에서 데이터를 복사하여 데이터를 생성하고 이를 두 아이디어 간의 성능 비교에 사용하는 데 도움이 됩니다.

순진한 접근 방식을 사용하여 특정 스택에서 중복 제거

다음은 Naïve 접근 방식을 사용하여 주어진 스택에서 중복 항목을 제거하는 단계입니다 −

  • 타이머를 시작하세요.
  • 빈 스택을 만들어 고유한 요소를 저장하세요.
  • while 루프를 사용하여 반복하고 원래 스택이 비어 있을 때까지 계속해서 최상위 요소를 팝합니다.
  • resultStack.contains(element)를 사용하여 중복 항목을 확인하여 해당 요소가 이미 결과 스택에 있는지 확인하세요.
  • 요소가 결과 스택에 없으면 resultStack에 추가하세요.
  • 종료 시간을 기록하고 소요된 총 시간을 계산하세요.
  • 결과 반환

아래는 Naïve 접근 방식을 사용하여 주어진 스택에서 중복 항목을 제거하는 Java 프로그램입니다 −

으아아아

순진한 접근 방식을 위해 우리는

Stack<Integer> data = initData(10L);
는 스택의 모든 요소를 ​​통과하는 첫 번째 루프를 처리하고, 두 번째 루프는 <pre class="brush:php;toolbar:false">Unique elements using Naive Approach: [1, 4, 3, 2, 8, 7, 5] Time spent for Naive Approach: 18200 nanoseconds Unique elements using Optimized Approach: [1, 4, 3, 2, 8, 7, 5] Time spent for Optimized Approach: 34800 nanoseconds</pre> 요소가 이미 존재하는지 확인하는 것입니다.

최적화된 접근 방식(HashSet)을 사용하여 주어진 스택에서 중복 항목을 제거합니다(HashSet)

다음은 최적화된 접근 방식을 사용하여 주어진 스택에서 중복 항목을 제거하는 단계입니다 −

  • 타이머 시작
  • 본 요소를 추적하기 위한 세트를 생성합니다(O(1) 복잡성 검사용).
  • 임시 스택을 만들어 고유한 요소를 저장하세요.
  • 스택이 빌 때까지 while 루프를 사용하여 반복합니다.
  • 스택에서 최상위 요소를 제거합니다.
  • 중복 항목을 확인하기 위해 seen.contains(element)를 사용하여 요소가 이미 세트에 있는지 확인합니다.
  • 요소가 세트에 없으면 표시된 스택과 임시 스택에 모두 추가하세요.
  • 종료 시간을 기록하고 소요된 총 시간을 계산하세요.
  • 결과 반환

아래는 HashSet −

을 사용하여 주어진 스택에서 중복 항목을 제거하는 Java 프로그램입니다. 으아아아

최적화된 접근 방식을 위해

를 사용합니다.
private static Stack initData(Long size) {
    Stack stack = new Stack < > ();
    Random random = new Random();
    int bound = (int) Math.ceil(size * 0.75);
    for (int i = 0; i < size; ++i) {
        stack.add(random.nextInt(bound) + 1);
    }
    return stack;
}

private static Stack < Integer > manualCloneStack(Stack < Integer > stack) {
    Stack < Integer > newStack = new Stack < > ();
    for (Integer item: stack) {
        newStack.push(item);
    }
    return newStack;
}
고유한 요소를 세트에 저장하려면 임의 요소에 액세스할 때 O(1) 복잡성을 활용하여 요소가 있는지 여부를 확인하는 계산 비용을 줄이세요.

두 가지 접근 방식을 함께 사용

다음은 위에서 언급한 두 가지 접근 방식을 사용하여 특정 스택에서 중복 항목을 제거하는 단계입니다.

  • 임의의 정수로 채워진 스택을 생성하기 위해 initData(Long size) 메소드를 사용하여 데이터를 초기화합니다.
  • cloneStack(Stack stack) 방법을 사용하여 원본 스택의 정확한 복사본을 생성하는 스택을 복제합니다.
  • initData를 사용하여 초기 스택을 생성합니다.
  • cloneStack을 사용하여 이 스택을 복제합니다.
  • 순진한 접근 방식을 적용하여 원본 스택에서 중복 항목을 제거합니다.
  • 복제된 스택에서 중복 항목을 제거하려면 최적화된 접근 방식을 적용하세요.
  • 각 방법에 소요된 시간과 두 접근 방식에서 생성된 고유 요소를 표시합니다.

예시 

아래는 위에서 언급한 두 가지 접근 방식을 모두 사용하여 스택에서 중복 요소를 제거하는 Java 프로그램입니다. −

으아아아

출력

Java program to remove duplicates from a given stack


비교

* 측정 단위는 나노초입니다.

public static void main(String[] args) {
    Stack<Integer> data1 = initData(<number of stack size want to test>);
    Stack<Integer> data2 = manualCloneStack(data1);
    idea1(data1);
    idea2(data2);
}
Method 100 elements 1000 elements 10000 elements
100000 elements
1000000 elements
Idea 1 693100 
4051600
19026900
114201800
1157256000
Idea 2 135800 
681400
2717800
11489400

36456100

As observed, the time running for Idea 2 is shorter than for Idea 1 because the complexity of Idea 1 is O(n²), while the complexity of Idea 2 is O(n). So, when the number of stacks increases, the time spent on calculations also increases based on it.


위 내용은 주어진 스택에서 중복을 제거하는 Java 프로그램의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

뜨거운 주제

수정 : Windows 업데이트가 설치되지 않았습니다 수정 : Windows 업데이트가 설치되지 않았습니다 Aug 08, 2025 pm 04:16 PM

runthewindowsupdateTrouBleShootErviaSettings> 업데이트 및 보안> 문제 해결을 해소 적으로 문제를 해결합니다 .2

Java 객체의 직렬화 과정은 무엇입니까? Java 객체의 직렬화 과정은 무엇입니까? Aug 08, 2025 pm 04:03 PM

JavaserializationConvertsanObject'sstateIntoAbytestreamforStorageOrtransmission, anddeserialization은 ThatStream.1. toenableserialization, aclassmustimplementtheserializableinterface.2.useObjectOutoutPutStreamToseAnobject, Savin

Java에서 while 루프를 사용하는 방법 Java에서 while 루프를 사용하는 방법 Aug 08, 2025 pm 04:04 PM

awhileloopinjavarepeatexecutescodeaslongasTheconditionistrue; 2. initializeacontrolvariablebarevereTeloop; 3. definephonditionusingabooleanexpression; 4.updateContrecontrolibarialinInsidethelooptopreventinfiniteLooping; 5.Useexamplass

Java의 해시 맵은 무엇입니까? Java의 해시 맵은 무엇입니까? Aug 11, 2025 pm 07:24 PM

ahashmapinjavaisadartructurestoreskey-valuepairsefairfairsforefficientRetrieval, insertion, anddeletion.itusestHekey'ShashCode () methodTodEterMinestoragelocationAldowSaverAgeo (1) timecomplexityforget () 및 putations.usitorderd, permitsonulkyAndm

자바에서 배열을 생성하고 사용하는 방법 자바에서 배열을 생성하고 사용하는 방법 Aug 11, 2025 pm 04:00 PM

TorecreateAnarrayinjava, FirstDeclareTheArraywithThedatAtypeandSquarebrackets, thenInstantiateTwithThenwithKeywordorinitializeItdirectlyWithValues; 1.decleAndcreateArrayusingDatatAty [] arrayName = newDatatype [Or.InitiDattyTyteate];

Java에서 스레드를 어떻게 만드나요? Java에서 스레드를 어떻게 만드나요? Aug 11, 2025 pm 01:34 PM

youcancreateathreadinjavabyextendingtheThreadClassOrimplementingTherunnableInterface.2

Python Argparse 필수 인수 예제 Python Argparse 필수 인수 예제 Aug 11, 2025 pm 09:42 PM

ArgParse 모듈을 사용하는 경우 필요한 = true를 설정하여 제공 해야하는 매개 변수를 달성 할 수 있습니다. 1. reque yewing = true 옵션 매개 변수 (예 : -입력)를 설정하려면 true가 필요합니다. 스크립트를 실행할 때 제공되지 않으면 오류 가보고됩니다. 2. 위치 매개 변수는 기본적으로 필요하며, 필요한 = true를 설정할 필요가 없습니다. 3. 필요한 매개 변수에 위치 매개 변수를 사용하는 것이 좋습니다. 때때로, 필요한 = true의 선택적 매개 변수는 유연성을 유지하는 데 사용됩니다. 4. 필수 = true는 매개 변수를 제어하는 가장 직접적인 방법입니다. 사용 후 사용자는 스크립트를 호출 할 때 해당 매개 변수를 제공해야합니다. 그렇지 않으면 프로그램에 오류가 발생하고 종료됩니다.

Java에서 세트를 사용하는 방법 Java에서 세트를 사용하는 방법 Aug 11, 2025 am 11:57 AM

ChooseTheAppropriatesEtimementation : useHashSetForfEStOperationswithOutOrder, LinkedHashSetForInsertionOrder.2.AdDlementSwitHAdd () AndRemoveWithRemove (), whereadd () returnSfalSeifTheelementIsalPresent.3.checkforelementsUsi

See all articles