찾다
웹 프론트엔드JS 튜토리얼자바스크립트 데이터 구조의 검색 알고리즘 및 Algorithm_javascript 기술

데이터를 찾는 방법에는 순차 검색과 이진 검색이 있습니다. 순차 검색은 무작위로 배열된 요소가 있는 목록에서 작동합니다. 이진 검색은 정렬된 요소 목록에서 작동합니다. 이진 검색은 더 효율적이지만 정렬된 목록 요소 집합이어야 합니다.

1: 순차검색
순차검색은 목록의 첫 번째 요소부터 시작하여 원하는 결과를 찾을 때까지, 또는 목록 끝까지 원하는 요소를 찾을 수 없을 때까지 목록 요소를 하나씩 판단하는 것입니다.

코드는 다음과 같습니다.

function seqSearch(data,arr) {
  for(var i = 0; i < arr.length; ++i) {
    if(arr[i] == data) {
      return true;
    }
  }
  return false;
}

요소의 위치에 맞는 순차 검색 기능을 반환할 수도 있습니다. 코드는 다음과 같습니다.

function seqSearch(data,arr) {
  for(var i = 0; i < arr.length; ++i) {
    if(arr[i] == data) {
      return i;
    }
  }
  return -1;
}

둘: 최소값과 최대값 찾기

배열에서 최소값을 찾는 알고리즘은 다음과 같습니다.

1. 배열의 첫 번째 요소를 변수에 할당하고 이 변수를 최소값으로 사용합니다.
2. 두 번째 요소부터 시작하여 배열 탐색을 시작하고 이를 현재 최소값과 비교합니다.
3. 현재 요소의 값이 현재 최소값보다 작은 경우 현재 요소를 새로운 최소값으로 설정합니다.
4. 다음 요소로 이동하여 3단계를 반복하세요.
5. 프로그램이 종료되면 이 변수에 저장되는 것은 최소값입니다.

코드는 다음과 같습니다.

function findMin(arr) {
  var min = arr[0];
  for(var i = 1; i < arr.length; ++i) {
    if(arr[i] < min) {
      min = arr[i];
    }
  }
  return min;
}

최대값을 찾는 알고리즘은 위의 최소값과 유사합니다. 먼저 배열의 첫 번째 요소를 최대값으로 설정한 다음 배열의 나머지 각 요소를 현재 최대값과 비교하는 루프를 반복합니다. 현재 요소의 값이 현재 최대값보다 큰 경우 해당 요소의 값을 최대값에 할당합니다. 코드는 다음과 같습니다.

function findMax(arr) {
  var max = arr[0];
  for(var i = 1; i < arr.length; ++i) {
    if(arr[i] > max) {
      max = arr[i];
    }
  }
  return max;
 }

셋: 이진 검색 방법.

찾고 있는 데이터가 순서대로 정렬된 경우에는 순차 검색 알고리즘보다 이진 검색 알고리즘이 더 효율적입니다. 이진 탐색 알고리즘의 기본 원리는 다음과 같습니다.

1. 배열의 첫 번째 위치를 하한(0)으로 설정합니다.
2. 배열의 마지막 요소 위치를 상한(배열의 길이에서 1을 뺀 값)으로 설정합니다.
3. 하한 경계가 상한 경계와 같거나 작은 경우 다음을 수행합니다.
A. 중간점을 (상한 경계 + 하한 경계)를 2로 나눈 값으로 설정합니다.
B. 중간점 요소가 쿼리 값보다 작은 경우, 중간점 요소의 첨자에 1을 더한 값을 하한값으로 설정합니다.
C. 중간점에 있는 요소가 쿼리 값보다 큰 경우, 중간점 요소의 첨자에서 1을 뺀 값으로 상한을 설정합니다.
D. 그렇지 않으면 중간점 요소가 찾아야 할 데이터이고 반환될 수 있다.

코드는 다음과 같습니다.

// 二分查找算法
function binSearch(data,arr) {
var lowerBound = 0;
  var upperBound = arr.length - 1;
  while(lowerBound <= upperBound) {
    var mid = Math.floor((upperBound + lowerBound)/2);
    if(arr[mid] < data) {
      lowerBound = mid + 1;
    }else if(arr[mid] > data) {
      upperBound = mid - 1;
    }else {
      return mid;
    }
  }
  return -1;
}
 // 快速排序
function qSort(list) {
  if(list.length == 0) {
    return [];
  }
  // 存储小于基准值的值
  var left = [];
  // 存储大于基准值的值
  var right = [];
  var pivot = list[0];
  for(var i = 1; i < list.length; i++) {
    if(list[i] < pivot) {
      left.push(list[i]);
    }else {
      right.push(list[i])
    }
  }
  return qSort(left).concat(pivot,qSort(right));
}
 // 测试代码
var numbers = [0,9,1,8,7,6,2,3,5,4];
var list = qSort(numbers);
console.log(binSearch(6,list));

4: 반복 횟수를 계산합니다.
이진 검색 알고리즘 binSearch() 함수가 특정 값을 찾았을 때, 데이터 세트에 다른 동일한 값이 있으면 함수는 비슷한 값 근처에 위치하게 됩니다. 즉, 다른 동일한 값이 있을 수 있습니다. 찾은 값의 왼쪽 또는 오른쪽이 나타납니다.

그러면 가장 간단한 해결책은 두 개의 루프를 작성하는 것입니다. 하나는 데이터 세트를 아래쪽이나 왼쪽으로 동시에 탐색하여 반복 횟수를 계산한 다음 위쪽이나 오른쪽으로 탐색하여 반복 횟수를 계산하는 것입니다. 코드는 다음과 같습니다.

// 计算重复次数
function count(data,arr) {
  var count = 0;
  var arrs = [];
  var position = binSearch(data,arr);
  if(position > -1) {
    ++count;
    arrs.push({"index":count});
    for(var i = position -1; i > 0; --i) {
      if(arr[i] == data) {
        ++count;
        arrs.push({"index":count});
      }else {
        break;
      }
    }
    for(var i = position + 1; i < arr.length; ++i) {
      if(arr[i] == data) {
        ++count;
        arrs.push({"index":count});
      }else {
        break;
      }
    }
  }
  return arrs;
}
 // 测试重复次数的代码
var arr = [0,1,1,1,2,3,4,5,6,7,8,9];
var arrs = count(1,arr);
console.log(arrs);
console.log(arrs.length);

아래 그림과 같습니다.

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Java中的二叉树结构详解Java中的二叉树结构详解Jun 16, 2023 am 08:58 AM

二叉树是计算机科学中常见的数据结构,也是Java编程中常用的一种数据结构。本文将详细介绍Java中的二叉树结构。一、什么是二叉树?在计算机科学中,二叉树是一种树形结构,每个节点最多有两个子节点。其中,左侧子节点比父节点小,右侧子节点则比父节点大。在Java编程中,常用二叉树表示排序,搜索以及提高对数据的查询效率。二、Java中的二叉树实现在Java中,二叉树

Python 实现栈的几种方式及其优劣Python 实现栈的几种方式及其优劣May 19, 2023 am 09:37 AM

​​想了解更多关于开源的内容,请访问:​​​​51CTO开源基础软件社区​​​​https://ost.51cto.com​​一、栈的概念栈由一系列对象对象组织的一个集合,这些对象的增加和删除操作都遵循一个“后进先出”(LastInFirstOut,LIFO)的原则。在任何时刻只能向栈中插入一个对象,但只能取得或者删除只能在栈顶进行。比如由书构成的栈,唯一露出封面的书就是顶部的那本,为了拿到其他的书,只能移除压在上面的书,如图:栈的实际应用实际上很多应用程序都会用到栈,比如:网络浏览器将最近浏览

PHP8中会支持的数据结构,将为你的代码提供更大空间PHP8中会支持的数据结构,将为你的代码提供更大空间Jun 21, 2023 am 08:13 AM

PHP是一种广泛使用的脚本语言,被广泛用于Web开发,服务器端编程以及命令行编程等。随着PHP不断更新和发展,它也日益成为一个更强大的编程工具,为用户提供了更多的功能和更多的工具来开发高质量的应用程序。其中,数据结构是一个非常重要的领域,一种有效的数据结构可以大大提高程序的性能和可读性。在这篇文章中,我们将讨论PHP8中支持的新数据结构,这些新的数据结构将让

如何解决Java中遇到的代码性能优化问题如何解决Java中遇到的代码性能优化问题Jun 29, 2023 am 10:13 AM

如何解决Java中遇到的代码性能优化问题随着现代软件应用的复杂性和数据量的增加,对于代码性能的需求也变得越来越高。在Java开发中,我们经常会遇到一些性能瓶颈,如何解决这些问题成为了开发者们关注的焦点。本文将介绍一些常见的Java代码性能优化问题,并提供一些解决方案。一、避免过多的对象创建和销毁在Java中,对象的创建和销毁是需要耗费资源的。因此,当一个方法

Java语言中的数据结构与算法介绍Java语言中的数据结构与算法介绍Jun 10, 2023 pm 01:37 PM

随着计算机科学的不断发展,数据结构与算法成为了计算机科学领域中最为基础、重要的模块。数据结构是一种组织和存储数据的方式,它是解决问题的基础。算法则是计算机科学的核心,它是指在计算机程序中解决问题的方法和技术。Java作为一种广泛应用的编程语言,其自带的数据结构和算法库是非常强大的,赋予了开发人员更多的力量。一、数据结构Java中提供了多种数据结构,包括数组

go语言有哪些数据结构go语言有哪些数据结构Dec 16, 2022 pm 02:00 PM

go语言数据结构有四大类:1、基础类型,包括整型(有符号和无符号整数)、浮点数、复数、字符串(由不可变的字节序列构成)、布尔值(只有true和false两个值);2、聚合类型,包括数组、结构体(是由任意个任意类型的变量组合在一起的数据类型);3、引用类型,包括指针、slice(是一个拥有相同元素的可变长度序列)、map、function、channel;4、接口类型。

PHP中的SPL扩展:用于处理集合、队列和堆栈等数据结构PHP中的SPL扩展:用于处理集合、队列和堆栈等数据结构May 11, 2023 pm 04:48 PM

在PHP中,数据结构是常见的编程概念之一。使用数据结构可以更有效地组织和管理数据,提高代码的可读性和可维护性。SPL(StandardPHPLibrary,标准PHP库)扩展是PHP中自带的一个功能强大的库,其中包含了许多常用的数据结构和算法,如集合、队列和堆栈等。本文将介绍SPL扩展,以及它在处理数据结构时的应用。SPL的简介SPL扩展是PHP内置的一

Go语言中的数据结构的实现方式Go语言中的数据结构的实现方式Jun 01, 2023 pm 06:51 PM

Go语言是一种支持并发编程的语言,它的内置数据结构非常丰富,可以满足不同场景下的需求。Go语言中实现数据结构的方式有多种,包括数组、切片、字典、链表和树。数组和切片是最基础的数据结构,它们都可以存储一组相同类型的元素。不同之处在于数组的长度是固定的,而切片则可以动态扩展。Go语言中使用数组和切片可以快速创建数据结构,例如著名的排序算法中的快速排序和归并排序都

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

뜨거운 도구

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구