Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- create table
- 28015
- STF_PortForwarding
- appium
- mysql
- STF
- PYTHON
- appium server
- 실행권한
- centos
- nGrinder
- nmap
- insert
- perfect
- openpyxl
- SWIFT
- Jupyter
- nohup
- GoCD
- kitura
- port forwarding
- ssh
- sshpass
- ubuntu
- ftp
- rethinkdb
- postgresql
- Jupyter Notebook
- postgres
- Materials
Archives
- Today
- Total
don't stop believing
Linear Search - 선형 검색 (순차 검색) 본문
이번에는 데이터를 찾는 알고리즘을 확인해 보겠습니다.
처음으로 선형 검색(Linear Search) 입니다. 이건 간단 합니다. 내가 찾으려는 값이 배열의 몇 번째 자리에 있는지 순차적으로 찾는 것입니다.
https://en.wikipedia.org/wiki/Linear_search
Go로 구현한 코드입니다.
package main import "fmt" // 찾으려는 값(key)이 있는지 배열의 0번부터 순차적으로 올라가며 찾습니다. func search(arr []int, key int) int { for i := 0; i < len(arr); i++ { if arr[i] == key { return i } } return -1 } func main() { searchValue := 10 // 우선 전제조건으로 검색하려는 배열은 정렬되어 있어야 합니다. arr := []int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10} fmt.Println(arr) found := search(arr, searchValue) if found == -1 { fmt.Println("Key not found") } else { fmt.Printf("Key found at position: %d\n", found) } }
찾으려는 값이 배열의 앞쪽에 있다면 빨리 찾겠지만 뒤에 있다면 효율이 가장 좋지 못할 것입니다.
'Golang > Basic' 카테고리의 다른 글
Binary Search - 이진 검색 (0) | 2019.05.13 |
---|---|
Jump Point Search - 점프 포인트 서치 (블록 탐색) (0) | 2019.05.13 |
Counting Sort - 계수 정렬 (0) | 2019.05.09 |
Shell Sort - 쉘 정렬 (0) | 2019.05.09 |
Insertion Sort - 삽입 정렬 (0) | 2019.05.08 |
Comments