線性查找


  線性查找也叫順序查找,這是最基本的一種查找方法,從給定的值中進行搜索,從一端開始逐一檢查每個元素,直到找到所需元素的過程。

  如果元素個數為 N,那么線性查找的平均次數為: N/2

  下面通過一個例子,演示線性查找:

import java.util.HashSet;
import java.util.Iterator;
import java.util.Set;

public class SequentialSearch {
	//定義一個數組,存放所有數據
	static int[] array = null;
	//定義一個 set 集合,用來排除數組中重復的數
	Set<Integer> setNum = new HashSet<>();
	//定義一個整型數,表示查找次數
	int times = 0;
	/**
	 * 根據傳入的 num 隨機產生 num 個不重復的數
	 * @param num
	 * @return
	 */
	public int[] createArray(int num){
		array = new int[num];
		while(setNum.size()!=num){
			int temp = (int)(Math.random()*10*num);
			setNum.add(temp);
		}
		
		int j = 0;
		Iterator<Integer> it = setNum.iterator();
		while(it.hasNext()){
			array[j] = it.next();
			j++;
		}
		
		return array;
	}
	
	/***
	 * 順序查找
	 * @return
	 */
	public int seqSearch(int num){
		array = createArray(10);//產生包含 10 個隨機數的 數組
		printArray(array);  //打印產生的隨機數組
		for(int i = 0 ; i< array.length ; i++){
			if(array[i] == num){
				times = i+1;	//如果找到了,返回找到的次數
			}else{
				times = -1;  //如果沒找到,返回 -1
			}
		}
		return times;
	}
	
	/***
	 * 打印數組
	 * @param array
	 */
	public void printArray(int [] array){
		if(array.length == 0){
			System.out.println("[]");
		}else{
			StringBuilder sb = new StringBuilder();
			sb.append('[');
			for(int i = 0 ; i < array.length ; i++){
				if(i == array.length-1){
					sb.append(array[i]+"]");
				}else{
					sb.append(array[i]+",");
				}
			}
			System.out.println(sb);
		}
	}
	
	
	public static void main(String[] args) {
		SequentialSearch ss = new SequentialSearch();
		System.out.println(ss.seqSearch(29)); //隨機查找一個數,比如 29
	}

}

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM