java基础算法五(散列 hash算法)

本文介绍了Java中的基础散列概念,强调了数组最大值与放入元素的关系,并通过代码示例展示其工作原理。同时,讨论了Hash冲突问题,指出大数组可能导致的空间浪费,为此引入了Hash算法以优化空间使用。文章最后提到了Hash冲突的解决方法,如线性探查和链表,并预告将在后续博客中进一步讲解。
摘要由CSDN通过智能技术生成

一,基础散列。

散列的思想很单一,以对应的数组下标对应,相应的值就可以了。比如:一个100位置的数组。当我将77放入时,应该放在下标为77的位置。这里有一点需要注意。

第一点,数组的最大值,是放入的最大值。比如数组100位置,那么我放入的最大值就不能超过99。这样当我们判断数组中的数是不是0,就知道它是否有值。(int类型的数组默认初始值是0);

上代码:

import java.util.Scanner;
/**
 * 散列思想
 *
 */
public class demo1 {
	public static void main(String[] args) {
		demo1 d=new demo1();
		d.Show();
	}
	private  int [] init(){
		System.out.println("请输入生成随机数个数");
		Scanner input=new Scanner(System.in);
		int nums=input.nextInt();
		System.out.print("请输入随机数最大范围");
		int max=input.nextInt();
		int [] ArrayNum=new int[max];
		int current=0;
		for(int i=0;i<nums;i++){
			current=(int) (Math.random()*max);
			ArrayNum[current]=current;
		}
		return ArrayNum;
		
	}
	private void Show(){
		int[] a=init();
		for (int c :a) {
				if(c!=0){
					System.out.print
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值