범위(1000000000000001) 내의 1000000000000000 표현식을 Python에서 얼마나 빨리 실행할 수 있나요?
요소인지 여부를 결정하는 가장 간단하고 조악한 방법은 O(n)입니다. 해시 알고리즘을 사용하는 이론적 시간 복잡도는 O(1)입니다. 그렇다면 Python은 이를 구현하기 위해 어떤 알고리즘을 사용할까요?
먼저 실험을 해보겠습니다:
#python2 timeit.timeit('1000000000 in range(0,1000000000,10)', number=1) 5.50357640805305 timeit.timeit('1000000000 in xrange(0,1000000000,10)', number=1) 2.3025200839183526 # python3 import timeit timeit.timeit('1000000000 in range(0,1000000000,10)', number=1) 4.490355838248402e-06
우리 모두는 Python2의 범위 함수가 모든 요소를 메모리에 한 번에 로드하는 목록 객체를 반환한다는 것을 알고 있습니다. 따라서 첫 번째 표현식이 실행되면 시스템이 갑자기 매우 느린 느낌을 받게 됩니다. , 5초 이상 소요됩니다.
xrange는 python3의 range 함수와 비슷합니다. 둘 다 반복자 객체를 반환하지만 실행 결과가 매우 다르기 때문에 놀랍습니다. 세 번째 표현식은 거의 0초가 걸립니다. python2의 xrange와 python3의 range 함수 사이에 왜 그렇게 큰 차이가 있습니까? 미스터리를 이해하기 위해서는 그 작업이 어떻게 수행되는지 이해해야 합니다. Python 문서의 in 규칙에 따르면:
클래스가 contain() 메서드를 구현하는 경우 y.contains(x)가 true를 반환하는 한 y의 x도 true를 반환하고 그 반대의 경우도 마찬가지입니다.
contains() 메소드는 구현되지 않았지만 iter() 메소드는 구현되었습니다. 그런 다음 반복 프로세스 중에 특정 값 z==x가 있으면 true를 반환하고 그렇지 않으면 false를 반환합니다.
위 두 메서드 중 어느 것도 구현되지 않은 경우 getitem() 메서드를 살펴보세요. x==y[i]와 같은 인덱스 i가 있으면 true를 반환하고, 그렇지 않으면 false를 반환합니다.
in의 규칙을 이해한 후 먼저 xrange가 제공하는 메서드를 살펴보겠습니다.
dir(xrange) ['__class__','__getitem__', '__hash__', '__init__', '__iter__', '__len__', '__new__', ...]
예, xrange 함수는 x가 y에 있는지 확인하기 위해 getitem과 iter만 구현합니다. 비교를 위한 것, 즉 xrange의 시간 복잡도가 O(n)이라고 가정해 보겠습니다.
python3의 range 메서드를 살펴보겠습니다.
dir(range) ['__class__', '__contains__', '__getitem__', '__iter__', 'count', 'index', 'start', 'step', 'stop', ...]
range는 xrange보다 더 많은 속성을 제공할 뿐만 아니라 포함도 구현하므로 포함 메서드를 먼저 호출합니다. 또한 세 가지 속성인 시작, 중지, 단계를 제공합니다. 그렇다면 정확히 왜 그렇게 빨리 실행되는 걸까요? Contains 메소드가 어떻게 구현되는지 살펴보겠습니다.
Python3에서는 값을 하나씩 반복적으로 비교하지 않고 다음과 같은 논리를 사용합니다.
먼저 x가 시작 범위와 중지 범위 사이에 있는지 확인합니다. start
이에서 진실이 드러납니다. moment, xrange 시간 복잡도는 O(1)입니다. 즉, xrange(start, stop, step)의 중지 값이 아무리 크더라도 시간 복잡도는 일정합니다. 따라서 python3의 range 메소드는 메모리를 절약할 수 있을 뿐만 아니라 더 효율적으로 수행할 수 있으므로 Python2를 배울지, Python3을 배울지 고민하지 마세요.
위 내용은 Python3에서 범위(1000000000000001)의 1000000000000000이 왜 그렇게 빠른가요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

Python은 배우고 사용하기 쉽고 C는 더 강력하지만 복잡합니다. 1. Python Syntax는 간결하며 초보자에게 적합합니다. 동적 타이핑 및 자동 메모리 관리를 사용하면 사용하기 쉽지만 런타임 오류가 발생할 수 있습니다. 2.C는 고성능 응용 프로그램에 적합한 저수준 제어 및 고급 기능을 제공하지만 학습 임계 값이 높고 수동 메모리 및 유형 안전 관리가 필요합니다.

Python과 C는 메모리 관리 및 제어에 상당한 차이가 있습니다. 1. Python은 참조 계산 및 쓰레기 수집을 기반으로 자동 메모리 관리를 사용하여 프로그래머의 작업을 단순화합니다. 2.C는 메모리 수동 관리가 필요하므로 더 많은 제어를 제공하지만 복잡성과 오류 위험을 증가시킵니다. 선택할 언어는 프로젝트 요구 사항 및 팀 기술 스택을 기반으로해야합니다.

과학 컴퓨팅에서 Python의 응용 프로그램에는 데이터 분석, 머신 러닝, 수치 시뮬레이션 및 시각화가 포함됩니다. 1.numpy는 효율적인 다차원 배열 및 수학적 함수를 제공합니다. 2. Scipy는 Numpy 기능을 확장하고 최적화 및 선형 대수 도구를 제공합니다. 3. 팬더는 데이터 처리 및 분석에 사용됩니다. 4. matplotlib는 다양한 그래프와 시각적 결과를 생성하는 데 사용됩니다.

Python 또는 C를 선택할 것인지 프로젝트 요구 사항에 따라 다릅니다. 1) Python은 간결한 구문 및 풍부한 라이브러리로 인해 빠른 개발, 데이터 과학 및 스크립팅에 적합합니다. 2) C는 컴파일 및 수동 메모리 관리로 인해 시스템 프로그래밍 및 게임 개발과 같은 고성능 및 기본 제어가 필요한 시나리오에 적합합니다.

Python은 데이터 과학 및 기계 학습에 널리 사용되며 주로 단순성과 강력한 라이브러리 생태계에 의존합니다. 1) 팬더는 데이터 처리 및 분석에 사용되며, 2) Numpy는 효율적인 수치 계산을 제공하며 3) Scikit-Learn은 기계 학습 모델 구성 및 최적화에 사용되며 이러한 라이브러리는 Python을 데이터 과학 및 기계 학습에 이상적인 도구로 만듭니다.

하루에 2 시간 동안 파이썬을 배우는 것으로 충분합니까? 목표와 학습 방법에 따라 다릅니다. 1) 명확한 학습 계획을 개발, 2) 적절한 학습 자원 및 방법을 선택하고 3) 실습 연습 및 검토 및 통합 연습 및 검토 및 통합,이 기간 동안 Python의 기본 지식과 고급 기능을 점차적으로 마스터 할 수 있습니다.

웹 개발에서 Python의 주요 응용 프로그램에는 Django 및 Flask 프레임 워크 사용, API 개발, 데이터 분석 및 시각화, 머신 러닝 및 AI 및 성능 최적화가 포함됩니다. 1. Django 및 Flask 프레임 워크 : Django는 복잡한 응용 분야의 빠른 개발에 적합하며 플라스크는 소형 또는 고도로 맞춤형 프로젝트에 적합합니다. 2. API 개발 : Flask 또는 DjangorestFramework를 사용하여 RESTFULAPI를 구축하십시오. 3. 데이터 분석 및 시각화 : Python을 사용하여 데이터를 처리하고 웹 인터페이스를 통해 표시합니다. 4. 머신 러닝 및 AI : 파이썬은 지능형 웹 애플리케이션을 구축하는 데 사용됩니다. 5. 성능 최적화 : 비동기 프로그래밍, 캐싱 및 코드를 통해 최적화

Python은 개발 효율에서 C보다 낫지 만 C는 실행 성능이 높습니다. 1. Python의 간결한 구문 및 풍부한 라이브러리는 개발 효율성을 향상시킵니다. 2.C의 컴파일 유형 특성 및 하드웨어 제어는 실행 성능을 향상시킵니다. 선택할 때는 프로젝트 요구에 따라 개발 속도 및 실행 효율성을 평가해야합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

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

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

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