线性查找

  线性查找也叫顺序查找,这是最基本的一种查找方法,从给定的值中进行搜索,从一端开始逐一检查每个元素,直到找到所需元素的过程。

  如果元素个数为 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
	}

}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏企鹅号快讯

Python网络爬虫之正则表达式

正则表达式非Python独有,在Python中通过re库模块实现。 ? 下面是一些常见的匹配模式 ? re.match re.match尝试从字符串的起始位置匹...

17210
来自专栏静默虚空的博客

[Java 基础]运算符和表达式

Java运算符 (1)赋值操作符 赋值操作符(=)表示:取右边的值(即右值),把它复制给左边(即左值)。 右值可以是任意的常量、变量或表达式(只要可以生成一个值...

1829
来自专栏程序员互动联盟

【编程基础】C语言类型转换

我们在编程序的时候,经常会出现不同类型的数据之间需要计算、赋值,必然会出现类型转换问题。C语言的变量数据类型是可以转换的,转换的方法有两类,一种是自动转换,一种...

35813
来自专栏noteless

[十二]基础数据类型之String

而对于字符的序列,也就是多个char, 这么一种东西, 使用CharSequence这个接口来描述

622
来自专栏cnblogs

ECMAScript5.1的运算符、类型转换总结

一、运算符优先级 从高到低 运算符 说明 () 圆括号     . [] new(带参数列表) 字段访问、数组索引、new(带参数列表) ()...

1667
来自专栏Python小屋

Python中的循环结构

Python主要有for循环和while循环两种形式的循环结构,多个循环可以嵌套使用,并且还经常和选择结构嵌套使用。while循环一般用于循环次数难以提前确定的...

3316
来自专栏十月梦想

数组截取slice和splice区别

在数组截取slice和splice都可以实现数组对象的截取,那么这两个有什么区别呢?当然我们先从代码实例推测一下!

683
来自专栏King_3的技术专栏

leetcode-541-Reverse String II

1455
来自专栏海天一树

小朋友学C语言(18):二进制

一、十进制与二进制 我们日常所用到的计数方式,是十进制(数字用0,1,2,3,4,5,6,7,8,9这十个数字来表示)。 十进制的进位规则是”逢十进一”。 比...

26710
来自专栏爱撒谎的男孩

快速排序算法

1686

扫码关注云+社区