Python을 사용한 배열의 파형 정렬
이 기사에서는 배열의 파형 정렬을 위한 Python 프로그램을 배웁니다.
정렬되지 않은 입력 배열이 있다고 가정합니다. 이제 입력 배열을 웨이브폼 방식으로 정렬하겠습니다. 배열 'arr [0..n-1]'이 arr [0] >= arr [1] = arr [3] =를 만족하는 경우 ...., 배열은 파형으로 정렬됩니다.
사용된 방법
이 작업을 수행하는 데 사용되는 다양한 방법은 다음과 같습니다 &miinus;
내장된 sort() 함수를 사용하세요
내장 기능을 사용하지 않음
방법 1: 내장된 sort() 함수 사용하기
알고리즘(단계)
다음은 원하는 작업을 수행하기 위해 따라야 할 알고리즘/단계입니다.
- 입력 배열과 배열 길이를 매개변수로 받아 입력 배열을 파형별로 정렬하는 함수를 만듭니다.
- 입력 배열을 오름차순으로 정렬하려면
sort() 함수(목록을 오름차순/내림차순으로 정렬)를 사용하세요.
-
for 루프를 사용하여 배열 길이까지 교대로 탐색합니다(단계=2)
- ',' 연산자를 사용하여 인접한 요소(예: 현재 요소와 다음 요소)를 바꿉니다.
- 입력 배열을 저장할 변수를 만듭니다.
-
len() 함수(객체의 항목 수를 반환함)를 사용하여 입력 배열의 길이를 가져옵니다.
- 입력 배열과 배열의 길이를 인수로 전달하여 위에 정의된
sortingInWaveform() 함수를 호출하세요
- 배열의 모든 요소를 반복하려면
for 루프를 사용하세요
- 배열의 현재 요소를 인쇄합니다.
다음 프로그램은 Python 내장 sort() 함수를 사용하여 파형의 입력 배열을 정렬합니다. −
으아악
출력실행 시 위 프로그램은 다음과 같은 출력을 생성합니다. 으아악 시간 복잡도
− O(nLogn). 여기서 주어진 배열은 정렬 함수를 사용하여 정렬되었으며 일반적으로 O(NlogN) 시간 복잡도를 갖습니다.
Merge Sort, Heap Sort
등 O(nLogn) 정렬 알고리즘을 적용하면 위에 제시된 방법의 시간 복잡도는 O(nLogn)입니다. 방법 2: 루프를 하나만 사용하세요
알고리즘(단계)
다음은 원하는 작업을 수행하기 위해 따라야 할 알고리즘/단계입니다.
0, 배열 길이 및 단계 값을 인수로 전달하여 모든 짝수 인덱스 요소를 탐색하려면- for 루프
- 를 사용하세요
- 문을 사용하여 현재 짝수 인덱스 요소가 이전 요소보다 작은지 확인하세요.
- 을 사용하여 현재 짝수 인덱스 요소가 다음 요소보다 작은지 확인하세요.
-
- 함수를 호출하세요
- 를 사용하세요.
-
으아악
출력위 프로그램을 실행하면 다음과 같은 출력이 생성됩니다 -
으아악
시간 복잡도
- O(n).여기에서는 정렬 기능을 사용하지 않고 대신 for 루프를 사용하여 주어진 배열의 요소를 반복했는데, 이는 평균적으로 O(N) 시간 복잡도를 갖습니다.
결론이 기사에서는 두 가지 방법을 사용하여 주어진 파형 배열을 정렬하는 방법을 배웠습니다. 우리는 첫 번째 방법에 비해 시간 복잡도가 O(log N) 감소한 새로운 논리를 사용했습니다. 대부분의 경우 이러한 유형의 알고리즘은 시간 복잡성을 줄이고 효율적인 솔루션을 구현하는 데 도움이 됩니다.
위 내용은 Python을 사용한 배열의 파형 정렬의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











Python의 Pandas 라이브러리를 사용할 때는 구조가 다른 두 데이터 프레임 사이에서 전체 열을 복사하는 방법이 일반적인 문제입니다. 두 개의 dats가 있다고 가정 해

파이썬 프로그래밍에서 Python 매개 변수 주석의 대체 사용법, 매개 변수 주석은 개발자가 기능을 더 잘 이해하고 사용하는 데 도움이되는 매우 유용한 기능입니다 ...

Python 크로스 플랫폼 데스크톱 응용 프로그램 개발 라이브러리 선택 많은 Python 개발자가 Windows 및 Linux 시스템 모두에서 실행할 수있는 데스크탑 응용 프로그램을 개발하고자합니다 ...

Python 스크립트는 특정 위치에서 Cursor 위치로 출력을 어떻게 제거합니까? Python 스크립트를 작성할 때 이전 출력을 커서 위치로 지우는 것이 일반적입니다 ...

내 코드가 API에 의해 데이터를 반환 할 수없는 이유는 무엇입니까? 프로그래밍에서 우리는 종종 API가 호출 될 때 NULL 값을 반환하는 문제를 겪는 경우가 종종 있습니다.

Uvicorn은 HTTP 요청을 어떻게 지속적으로 듣습니까? Uvicorn은 ASGI를 기반으로 한 가벼운 웹 서버입니다. 핵심 기능 중 하나는 HTTP 요청을 듣고 진행하는 것입니다 ...

파이썬에서 문자열을 통해 객체를 동적으로 생성하고 메소드를 호출하는 방법은 무엇입니까? 특히 구성 또는 실행 해야하는 경우 일반적인 프로그래밍 요구 사항입니다.

Python : 모래 시계 그래픽 도면 및 입력 검증을 시작 하기이 기사는 모래 시계 그래픽 드로잉 프로그램에서 Python 초보자가 발생하는 변수 정의 문제를 해결합니다. 암호...
