이번에는 JS 동적 프로그래밍 사용에 대해 자세히 설명하겠습니다. JS 동적 프로그래밍 사용 시 주의 사항은 무엇인가요? 실제 사례를 살펴보겠습니다.
사실 저희 프론트엔드 개발에서는 고급 알고리즘을 많이 사용하지 않습니다. 대부분의 경우 if 문, for 문, switch 문 등을 해결할 수 있습니다. 조금 더 복잡하다면 재귀를 사용하여 해결하는 것을 생각해 볼 수도 있습니다.
그러나 재귀는 작성하기는 간단하지만 실제로 실행에는 그다지 효율적이지 않다는 점에 유의해야 합니다.
동적 프로그래밍 알고리즘을 다시 살펴보겠습니다.
동적 프로그래밍 솔루션은 맨 아래부터 시작하여 모든 작은 문제를 해결한 다음 이를 전체적인 솔루션으로 결합하여 전체 큰 문제를 해결합니다.
예(피보나치 수열 계산)
피보나치 수열은 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233, 377, 610, 987, 1597, 2584, 4181, 6765, 10946의 수열을 말합니다. , 17711, 28657, 46368...
이 순서는 항목 3부터 시작하며 각 항목은 이전 두 항목의 합계와 같습니다.
이 시퀀스의 경우 재귀 함수를 사용하여 n번째 항목 값
// 斐波那契数列 function recurFib(n) { if(n "); return recurFib(n-1)+recurFib(n-2) } }
을 계산할 수 있습니다. 실제로는 매우 간결한 코드입니다. 위의 주석 처리된 코드는 n =일 때 함수를 몇 번 실행해야 하는지 출력하는 데 사용됩니다. 그러나 안목 있는 사람은 n이 증가함에 따라 실행 횟수가 증가한다는 것을 한눈에 알 수 있습니다. . 매우 무서운 성장.
n=5일 때 재귀 트리가 매우 커졌습니다... n=10, 심지어 n=100일 때...
재귀함수의 실행 효율성 차이를 이해하고, 동적 프로그래밍이 어떻게 이루어지는지 살펴보겠습니다
function dynFib(n) { let val = []; for(let i = 0; i <p style="text-align: left;"> 중간 결과는 배열 val에 저장됩니다. 계산할 피보나치 수가 1 또는 2이면 if 문은 1을 반환합니다. 그렇지 않으면 값 1과 2가 val 배열의 위치 1과 2에 저장됩니다. </p><p style="text-align: left;"> 루프는 3에서 입력 매개변수까지 이동하고 배열의 각 요소를 처음 두 요소의 합에 할당합니다. 루프가 끝나면 배열의 마지막 요소 값이 최종 계산된 피보나치 값이 됩니다. <a href="http://www.php.cn/code/6029.html" target="_blank"> 함수의 반환 값 </a>으로 사용됩니다. </p><p style="text-align: left;"> 다음으로 두 함수의 실행 시간을 비교하는 간단한 테스트 함수를 작성할 수 있습니다. </p>rreee<p style="text-align: left;"> 인쇄 기능 실행</p><pre class="brush:php;toolbar:false">// 定义一个测试函数,将待测函数作为参数传入 function test(func,n){ let start = new Date().getTime();//起始时间 let res = func(n);//执行待测函数 document.write('<br>'+'当n='+n+'的时候 '+res+'<br>'); let end = new Date().getTime();//结束时间 return (end - start)+"ms";//返回函数执行需要时间 }
결과는 다음과 같습니다:
마지막으로, 반복적 접근 방식을 사용할 때 배열을 사용하지 않고 피보나치 수열을 계산하는 것이 가능하다는 것을 깨달았을 것입니다.
배열이 필요한 이유는 동적 프로그래밍 알고리즘이 일반적으로 중간 결과를 저장해야 하기 때문입니다.
다음은
let time = test(recurFib,40); document.write(time); let time2 = test(dynFib,40); document.write(time2);
를 의미하는 피보나치 함수의 반복 버전입니다. 물론 이번 반복 버전의 효율성은 어레이 버전과 동일하다.
이 기사의 사례를 읽은 후 방법을 마스터했다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!
추천 도서:
위 내용은 JS 동적 프로그래밍 사용에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

예, JavaScript의 엔진 코어는 C로 작성되었습니다. 1) C 언어는 효율적인 성능과 기본 제어를 제공하며, 이는 JavaScript 엔진 개발에 적합합니다. 2) V8 엔진을 예를 들어, 핵심은 C로 작성되며 C의 효율성 및 객체 지향적 특성을 결합하여 C로 작성됩니다.

JavaScript는 웹 페이지의 상호 작용과 역학을 향상시키기 때문에 현대 웹 사이트의 핵심입니다. 1) 페이지를 새로 고치지 않고 콘텐츠를 변경할 수 있습니다. 2) Domapi를 통해 웹 페이지 조작, 3) 애니메이션 및 드래그 앤 드롭과 같은 복잡한 대화식 효과를 지원합니다. 4) 성능 및 모범 사례를 최적화하여 사용자 경험을 향상시킵니다.

C 및 JavaScript는 WebAssembly를 통한 상호 운용성을 달성합니다. 1) C 코드는 WebAssembly 모듈로 컴파일되어 컴퓨팅 전력을 향상시키기 위해 JavaScript 환경에 도입됩니다. 2) 게임 개발에서 C는 물리 엔진 및 그래픽 렌더링을 처리하며 JavaScript는 게임 로직 및 사용자 인터페이스를 담당합니다.

JavaScript는 웹 사이트, 모바일 응용 프로그램, 데스크탑 응용 프로그램 및 서버 측 프로그래밍에서 널리 사용됩니다. 1) 웹 사이트 개발에서 JavaScript는 HTML 및 CSS와 함께 DOM을 운영하여 동적 효과를 달성하고 jQuery 및 React와 같은 프레임 워크를 지원합니다. 2) 반응 및 이온 성을 통해 JavaScript는 크로스 플랫폼 모바일 애플리케이션을 개발하는 데 사용됩니다. 3) 전자 프레임 워크를 사용하면 JavaScript가 데스크탑 애플리케이션을 구축 할 수 있습니다. 4) node.js는 JavaScript가 서버 측에서 실행되도록하고 동시 요청이 높은 높은 요청을 지원합니다.

Python은 데이터 과학 및 자동화에 더 적합한 반면 JavaScript는 프론트 엔드 및 풀 스택 개발에 더 적합합니다. 1. Python은 데이터 처리 및 모델링을 위해 Numpy 및 Pandas와 같은 라이브러리를 사용하여 데이터 과학 및 기계 학습에서 잘 수행됩니다. 2. 파이썬은 간결하고 자동화 및 스크립팅이 효율적입니다. 3. JavaScript는 프론트 엔드 개발에 없어서는 안될 것이며 동적 웹 페이지 및 단일 페이지 응용 프로그램을 구축하는 데 사용됩니다. 4. JavaScript는 Node.js를 통해 백엔드 개발에 역할을하며 전체 스택 개발을 지원합니다.

C와 C는 주로 통역사와 JIT 컴파일러를 구현하는 데 사용되는 JavaScript 엔진에서 중요한 역할을합니다. 1) C는 JavaScript 소스 코드를 구문 분석하고 추상 구문 트리를 생성하는 데 사용됩니다. 2) C는 바이트 코드 생성 및 실행을 담당합니다. 3) C는 JIT 컴파일러를 구현하고 런타임에 핫스팟 코드를 최적화하고 컴파일하며 JavaScript의 실행 효율을 크게 향상시킵니다.

실제 세계에서 JavaScript의 응용 프로그램에는 프론트 엔드 및 백엔드 개발이 포함됩니다. 1) DOM 운영 및 이벤트 처리와 관련된 TODO 목록 응용 프로그램을 구축하여 프론트 엔드 애플리케이션을 표시합니다. 2) Node.js를 통해 RESTFULAPI를 구축하고 Express를 통해 백엔드 응용 프로그램을 시연하십시오.

웹 개발에서 JavaScript의 주요 용도에는 클라이언트 상호 작용, 양식 검증 및 비동기 통신이 포함됩니다. 1) DOM 운영을 통한 동적 컨텐츠 업데이트 및 사용자 상호 작용; 2) 사용자가 사용자 경험을 향상시키기 위해 데이터를 제출하기 전에 클라이언트 확인이 수행됩니다. 3) 서버와의 진실한 통신은 Ajax 기술을 통해 달성됩니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

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

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

WebStorm Mac 버전
유용한 JavaScript 개발 도구
