java map 二维数组_Java二维数组实现简单Map

java map 二维数组_Java二维数组实现简单Map这些天频繁的在使用二维数组,让我觉得二维数组要比Map更灵活多变,以前和别人提起“数据结构”总能听到有人问:“如果编程语言里没有HashMap,你能自己实现一个Map来用么?”。熟练了二维数组,今天我就来尝试实现一个最简单的Map吧,我没有参考网上的例子,也没去想数据结构书中是怎么讲的,纯粹的自己个一个设计方案,中途遇到很多问题,但还是逐个解决了,还有很多不足之处,希望大家能帮我指点指点,一起交流…

大家好,又见面了,我是你们的朋友全栈君。

这些天频繁的在使用二维数组,让我觉得二维数组要比Map更灵活多变,以前和别人提起“数据结构”总能听到有人问:“如果编程语言里没有HashMap,你能自己实现一个Map来用么?”。熟练了二维数组,今天我就来尝试实现一个最简单的Map吧,我没有参考网上的例子,也没去想数据结构书中是怎么讲的,纯粹的自己个一个设计方案,中途遇到很多问题,但还是逐个解决了,还有很多不足之处,希望大家能帮我指点指点,一起交流一下学术。好了,不多说了,还是第一次去实现Map这东西,先看代码吧~

package com.lj.test;

/**

* 简单的Map实现,采用二维数组实现(MapNew)

* @author LiangJian

* StartTime:2011-6-22 10:31:25

* EndTime:2011-6-22 17:46:15

*/

public class MapNew {

private int index = 0;

private String[][] map_tmp,map= null;

/**

* 存储数据(如果Key值重复,则会被覆盖掉)

* @param k key值

* @param v value值

*/

public void put(String k,String v){

map_tmp = getAddSize(map_tmp,index+1);//(每次增加一条数据就创建一个指定长度的新数组,并将数据拷贝进去)

map = getAddSize(map,index+1);//将数组空间增加一条存储位置,用于下面存储一条新数据。

boolean flag = isRepeat(map, k, v);//查看是否重复,如果重复则直接替换新的Value值

if(!flag){

map_tmp[index][0] = k;

map_tmp[index][1] = v;

index++;

//插入一条新的数据,拷贝到新数组中。从倒数第2条位置插入到倒数第2条索引位置1条数据。

System.arraycopy(map_tmp, map.length-1, map, map.length-1, 1);

}

}

/**

* 通过Key值获取数据

* @param key key值

* @return

*/

public String get(String key){

String value = null;

for(int i=0;i

if(key.equals(map[i][0])){

value = map[i][1];

break;

}

}

return value;

}

/** Map总长度 */

public int size(){

return map.length;

}

/**

* 增加二维数组的存储空间,数据不变

* @param map 要增长的数组

* @param length 新的长度

* @return

*/

public String[][] getAddSize(String[][] map,int length){

if(map ==null) map = new String[1][2];//创建单条数据数组长度

String[][] tmp = new String[length][2];//创建新的数组

System.arraycopy(map, 0, tmp, 0, map.length);//将原始数据拷贝到新的数组中

map = null;//不需要了,等待自动垃圾回收

return tmp;

}

/**

* 查看是否有重复key,如果已有则覆盖相应Value

* @param s 模拟Map的二维数组

* @param k key值

* @param v value值

* @return 如果有重复值,则返回true,否则返回false;

*/

public boolean isRepeat(String[][] s,String k,String v){

boolean flag = false;

for(int i=0;i

if(k.equals(s[i][0])){//查看是否存在此Key值

s[i][1] = v;//使用新的Value值

flag = true;

break;

}

}

return flag;

}

public static void main(String[] args) {

for(int i=0;i<=0;i++){

MapNew map = new MapNew();

map.put(“username”+i, “LiangJian”+i);

map.put(“username”+i, “LiangJian555重复的Key值插入”+i);

map.put(“password”+i, “123456”+i);

map.put(“sex”+i, “男”+i);

map.put(“qq”+i, “15141739”+i);

String username = map.get(“username”+i);

String password = map.get(“password”+i);

String sex = map.get(“sex”+i);

String qq = map.get(“qq”+i);

System.out.println(“——————“);

System.out.println(“username:”+username);

System.out.println(“password:”+password);

System.out.println(“sex:”+sex);

System.out.println(“qq:”+qq);

System.out.println(“——————-“);

System.out.println(“Map长度:”+map.size());

}

}

}

下载次数: 25

1

1

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2011-06-22 17:49

浏览 4352

评论

1 楼

chuanwang66

2011-06-23

建议用红黑树实现^_^

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/141972.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • matlab高斯型隶属函数,图高斯型隶属函数.PPT[通俗易懂]

    matlab高斯型隶属函数,图高斯型隶属函数.PPT[通俗易懂]图高斯型隶属函数第三章模糊控制的理论基础第一节概述第二节模糊集合第三节隶属函数第四节模糊关系第五节模糊推理在模糊控制中应用较多的隶属函数有以下6种隶属函数。(1)高斯型隶属函数高斯型隶属函数由两个参数和c确定:其中参数b通常为正,参数c用于确定曲线的中心。Matlab表示为(2)广义钟型隶属函数广义钟型隶属函数由…

    2025年7月27日
    2
  • 如何使用yum卸载mysql数据库_yum卸载mysql数据库方法(linux centos系统)

    如何使用yum卸载mysql数据库_yum卸载mysql数据库方法(linux centos系统)如何在linuxcentos系统中使用yum命令卸载mysql数据库呢?只需要使用yumremove命令即可轻松卸载mysql数据库了,方法很简单,只需要两个步骤即可。步骤一:执行下面的命令,查询有哪些mysql安装包可以卸载的,如下。[root@VM_230_32_centos~]#rpm-qa|grepmysqlphp-mysqlnd-5.6.32-1.el7.remi.x86…

    2022年5月22日
    38
  • 从简单的信道预计说起

    从简单的信道预计说起

    2021年11月15日
    40
  • JavaScript实现进制转换

    JavaScript实现进制转换

    2022年3月12日
    38
  • 计算机毕业设计net作业管理系统(系统+数据库+源码+文档)

    计算机毕业设计net作业管理系统(系统+数据库+源码+文档)计算机毕业设计net作业管理系统(系统+数据库+源码+文档)net作业管理系统计算机毕业设计最新计算机专业原创开发毕业设计参考选题都有源码+数据库是近期作品【1】 jsp科技专业师生沟通平台 【2】 ssm电商平台客流统计系统 【3】 JSP物流仓储仓库管理系统的设计与实现sqlserver 【4】 ssm大学生家教管理系统 【5】 ssm图书管理系统 【6】 ssm医院患者管理系统 【7】 班级信息管理系统 【8】

    2022年6月5日
    26
  • 局域网vlan配置步骤_局域网vlan划分案例

    局域网vlan配置步骤_局域网vlan划分案例计算机网络技术的发展犹如戏剧舞台,你方唱罢我登台。从传统的以太网(10Mb/s)发展到快速以太网(100Mb/s)和千兆以太网(1000Mb/s)也不过几年的时间,其迅猛的势头实在令人吃惊。而现在中大型规模网络建设中,以千兆三层交换机为核心的所谓“千兆主干跑、百兆到桌面”的主流网络模型已不胜枚举。现在,网络业界对“三层交换”和VLAN这两词已经不感到陌生了。一、什么是三…

    2022年9月18日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号