Python에서 일반적으로 사용되는 정렬 예제 공유
정렬 알고리즘의 안정성과 중요성
버블 정렬
복잡성과 안정성
선택 정렬
삽입 정렬
-
힐 정렬
-
빠른 정렬
일반적인 정렬 알고리즘의 효율성 비교
정렬 알고리즘의 안정성과 중요성
정렬할 순서에는 동일한 키워드를 가진 레코드가 있지만 정렬 후에도 이들 레코드의 상대적 순서는 변경되지 않습니다. , 정렬 알고리즘이 안정적입니다.
정렬이 불안정하면 여러 키워드의 정렬을 완료할 수 없습니다. 예를 들어 정수 정렬은 자릿수가 높을수록 우선 순위가 높아지며 높은 자릿수에서 낮은 자릿수로 정렬됩니다. 그러면 각 비트를 정렬하려면 안정적인 알고리즘이 필요합니다. 그렇지 않으면 올바른 결과를 얻을 수 없습니다.
즉, 여러 키워드를 여러 번 정렬하려면 안정적인 알고리즘을 사용해야 합니다.
버블 정렬
행
def bubble_sort(alist): """ 冒泡排序 """ if len(alist) <= 1: return alist for j in range(len(alist)-1,0,-1): for i in range(j): if alist[i] > alist[i+1]: alist[i], alist[i+1] = alist[i+1], alist[i] return alist
복잡성과 안정성
최적의 시간 복잡도: ( O(n) ) 순회에서 교환 가능한 요소를 찾지 못하고 정렬이 종료됩니다
최악의 시간 복잡도: (O(n^2))
안정성: 안정적
선택 정렬
선택 정렬은 다음과 같습니다. 간단하고 직관적인 정렬 알고리즘. 작동 방식은 다음과 같습니다. 먼저 정렬되지 않은 시퀀스에서 가장 작은(큰) 요소를 찾아 정렬된 시퀀스의 시작 부분에 저장한 다음, 정렬되지 않은 나머지 요소에서 계속해서 가장 작은(큰) 요소를 찾아 마지막에 넣습니다. 정렬된 순서. 모든 요소가 정렬될 때까지 계속됩니다.
삽입 정렬
삽입 정렬은 정렬되지 않은 데이터의 경우 정렬된 순서를 뒤에서 앞으로 스캔하여 해당 위치를 찾아 삽입합니다. 삽입 정렬의 구현에서는 뒤에서 앞으로 스캔하는 과정에서 정렬된 요소를 반복적으로 점진적으로 뒤로 이동하여 최신 요소에 대한 삽입 공간을 제공해야 합니다.
행
def insert_sort(alist): """ 插入排序 """ n = len(alist) if n <= 1: return alist # 从第二个位置,即下表为1的元素开始向前插入 for i in range(1, n): j = i # 向前向前比较,如果小于前一个元素,交换两个元素 while alist[j] < alist[j-1] and j > 0: alist[j], alist[j-1] = alist[j-1], alist[j] j-=1 return alist
복잡도 및 안정성
최적의 시간 복잡도: O((n)) (오름차순으로 정렬, 시퀀스는 이미 오름차순)
최악의 시간 복잡도: O( (n ^2))
안정성: 안정적
Hill Sort
Hill Sort(Shell Sort)는 삽입 정렬을 개선한 것으로 정렬이 안정적이지 않습니다. 힐 정렬은 첨자의 특정 증분으로 레코드를 그룹화하고 직접 삽입 정렬 알고리즘을 사용하여 각 그룹을 정렬하는 것입니다. 증분이 1로 줄어들면 각 그룹에는 더 많은 키워드가 포함됩니다. 이번에는 전체 파일을 하나의 그룹으로 나누고 알고리즘을 종료합니다.
def shell_sort(alist): n = len(alist) gap = n//2 # gap 变化到0之前,插入算法之行的次数 while gap > 0: # 希尔排序, 与普通的插入算法的区别就是gap步长 for i in range(gap,n): j = i while alist[j] < alist[j-gap] and j > 0: alist[j], alist[j-gap] = alist[j-gap], alist[j] j-=gap gap = gap//2 return alist
복잡도 및 안정성
최적의 시간 복잡도: (O(n^{1.3})) (주문할 필요 없음)
최악의 시간 복잡도: (O(n^) 2))
안정성: 불안정
퀵 정렬
퀵 정렬(Quicksort)은 정렬할 데이터를 하나의 정렬을 통해 독립적인 두 부분으로 나누고 한 부분의 모든 데이터가 다른 부분보다 우수해야 합니다. 그런 다음 이 방법을 사용하면 데이터의 두 부분을 각각 빠르게 정렬할 수 있으므로 전체 정렬 프로세스를 반복적으로 수행할 수 있으므로 전체 데이터가 정렬된 시퀀스가 됩니다.
단계는 다음과 같습니다.
시퀀스에서 "피벗"이라는 요소를 선택합니다.
시퀀스를 재정렬합니다. 피벗 값보다 작은 모든 요소는 피벗 값 앞에 배치되고, 피벗 값보다 작은 모든 요소는 피벗 값은 피벗 앞에 배치됩니다. 더 큰 값을 갖는 값이 베이스 뒤에 배치됩니다(동일한 숫자는 양쪽에 있을 수 있음). 이 분할 후 데이텀은 시퀀스의 중간에 있습니다. 이를 파티션 작업이라고 합니다.
기본 값보다 작은 요소의 하위 배열과 기본 값보다 큰 요소의 하위 배열을 재귀적으로 정렬합니다.
재귀의 가장 낮은 경우는 배열의 크기가 0 또는 1인 경우, 즉 항상 정렬된 경우입니다. 계속 반복되지만 이 알고리즘은 항상 종료됩니다. 왜냐하면 각 반복(반복)에서 최소한 하나의 요소를 최종 위치로 이동하기 때문입니다.
일반적인 정렬 알고리즘의 효율성 비교
되기도
위 내용은 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)

뜨거운 주제











2 시간 이내에 Python의 기본 프로그래밍 개념과 기술을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우기, 2. 마스터 제어 흐름 (조건부 명세서 및 루프), 3. 기능의 정의 및 사용을 이해하십시오. 4. 간단한 예제 및 코드 스 니펫을 통해 Python 프로그래밍을 신속하게 시작하십시오.

Python은 웹 개발, 데이터 과학, 기계 학습, 자동화 및 스크립팅 분야에서 널리 사용됩니다. 1) 웹 개발에서 Django 및 Flask 프레임 워크는 개발 프로세스를 단순화합니다. 2) 데이터 과학 및 기계 학습 분야에서 Numpy, Pandas, Scikit-Learn 및 Tensorflow 라이브러리는 강력한 지원을 제공합니다. 3) 자동화 및 스크립팅 측면에서 Python은 자동화 된 테스트 및 시스템 관리와 같은 작업에 적합합니다.

해시 값으로 저장되기 때문에 MongoDB 비밀번호를 Navicat을 통해 직접 보는 것은 불가능합니다. 분실 된 비밀번호 검색 방법 : 1. 비밀번호 재설정; 2. 구성 파일 확인 (해시 값이 포함될 수 있음); 3. 코드를 점검하십시오 (암호 하드 코드 메일).

데이터 전문가는 다양한 소스에서 많은 양의 데이터를 처리해야합니다. 이것은 데이터 관리 및 분석에 어려움을 겪을 수 있습니다. 다행히도 AWS Glue와 Amazon Athena의 두 가지 AWS 서비스가 도움이 될 수 있습니다.

Redis 서버를 시작하는 단계에는 다음이 포함됩니다. 운영 체제에 따라 Redis 설치. Redis-Server (Linux/MacOS) 또는 Redis-Server.exe (Windows)를 통해 Redis 서비스를 시작하십시오. Redis-Cli Ping (Linux/MacOS) 또는 Redis-Cli.exe Ping (Windows) 명령을 사용하여 서비스 상태를 확인하십시오. Redis-Cli, Python 또는 Node.js와 같은 Redis 클라이언트를 사용하여 서버에 액세스하십시오.

Redis의 대기열을 읽으려면 대기열 이름을 얻고 LPOP 명령을 사용하여 요소를 읽고 빈 큐를 처리해야합니다. 특정 단계는 다음과 같습니다. 대기열 이름 가져 오기 : "큐 :"와 같은 "대기열 : my-queue"의 접두사로 이름을 지정하십시오. LPOP 명령을 사용하십시오. 빈 대기열 처리 : 대기열이 비어 있으면 LPOP이 NIL을 반환하고 요소를 읽기 전에 대기열이 존재하는지 확인할 수 있습니다.

질문 : Redis 서버 버전을 보는 방법은 무엇입니까? 명령 줄 도구 Redis-Cli를 사용하여 연결된 서버의 버전을보십시오. 정보 서버 명령을 사용하여 서버의 내부 버전을보고 정보를 구문 분석하고 반환해야합니다. 클러스터 환경에서 각 노드의 버전 일관성을 확인하고 스크립트를 사용하여 자동으로 확인할 수 있습니다. 스크립트를 사용하여 Python 스크립트와 연결 및 인쇄 버전 정보와 같은보기 버전을 자동화하십시오.

Navicat의 비밀번호 보안은 대칭 암호화, 암호 강도 및 보안 측정의 조합에 의존합니다. 특정 측정에는 다음이 포함됩니다. SSL 연결 사용 (데이터베이스 서버가 인증서를 지원하고 올바르게 구성하는 경우), 정기적으로 Navicat을 업데이트하고보다 안전한 방법 (예 : SSH 터널), 액세스 권한 제한 및 가장 중요한 것은 암호를 기록하지 않습니다.
