实现一个简易的HashMap
实现一个键的类型为int,值的类型为int的HashMap
输入一个T,表示操作次数;
之后每行接一个操作,可以包括插入、删除、修改、查询、清空、判断是否有这个键;
因为是刚学完随手敲的,所以功能粗糙。插入不考虑键已经存在的情况。删除、修改、查询不考虑键不存在的情况;
#include "bits/stdc++.h"
using namespace std;
typedef long long LL;
const int INF = 0x3f3f3f3f;
// 因为int的数据范围为1 << 32 个数。所以把哈希表开到1 << 16从内存和效率上讲比较折中
const int SIZE = << ;
struct Map {
int key;
int value;
Map* next;
}*hashtable[SIZE];
int hashCode(int k) {
int code = k % SIZE;
return code < ? -code : code;
}
Map* init(int k, int v, Map* next) {
Map* point = (Map*)malloc(sizeof(Map));
point->key = k;
point->value = v;
point->next = next;
return point;
}
void insert(int k, int v) {
int id = hashCode(k);
hashtable[id] = init(k, v, hashtable[id]);
}
void update(int k, int v) {
int id = hashCode(k);
Map* point = hashtable[id];
while (point != NULL) {
if (point->key == k) {
point->value = v;
return;
}
point = point->next;
}
}
int query(int k) {
int id = hashCode(k);
Map* point = hashtable[id];
while (point != NULL) {
if (point->key == k) {
return point->value;
}
point = point->next;
}
}
bool hasKey(int k) {
int id = hashCode(k);
Map* point = hashtable[id];
while (point != NULL) {
if (point->key == k) {
return true;
}
point = point->next;
}
return false;
}
void erase(int k) {
int id = hashCode(k);
Map* pre = hashtable[id];
if (pre == NULL){
return;
}
if (pre->key == k) {
hashtable[id] = NULL;
return;
}
Map* now = pre->next;
while (now != NULL) {
if (now->key == k) {
pre->next = now->next;
free(now);
return;
}
pre = now;
now = now->next;
}
}
void clear() {
for (int i = ; i < SIZE; i++) {
Map* point = hashtable[i];
Map* next;
while (point != NULL) {
next = point->next;
free(point);
point = next;
}
hashtable[i]=NULL;
}
}
int main() {
int T, k, v;
char op[];
scanf("%d", &T);
while (T--) {
scanf("%s", op);
if (strcmp("insert", op) == ) {
scanf("%d%d", &k, &v);
insert(k, v);
} else if (strcmp("update", op) == ) {
scanf("%d%d", &k, &v);
update(k, v);
} else if (strcmp("query", op) == ) {
scanf("%d", &k);
printf("%d\n", query(k));
} else if (strcmp("hasKey", op) == ) {
scanf("%d", &k);
puts(hasKey(k) ? "Yes" : "No");
} else if (strcmp("erase", op) == ) {
scanf("%d", &k);
erase(k);
} else if (strcmp("clear", op) == ) {
clear();
}
}
return ;
}
实现一个简易的HashMap的更多相关文章
- 手动实现一个简易版SpringMvc
版权声明:本篇博客大部分代码引用于公众号:java团长,我只是在作者基础上稍微修改一些内容,内容仅供学习与参考 前言:目前mvc框架经过大浪淘沙,由最初的struts1到struts2,到目前的主流框 ...
- .NET Core的文件系统[5]:扩展文件系统构建一个简易版“云盘”
FileProvider构建了一个抽象文件系统,作为它的两个具体实现,PhysicalFileProvider和EmbeddedFileProvider则分别为我们构建了一个物理文件系统和程序集内嵌文 ...
- 自己来实现一个简易的OCR
来做个简易的字符识别 ,既然是简易的 那么我们就不能用任何的第三方库 .啥谷歌的 tesseract-ocr, opencv 之类的 那些玩意是叼 至少图像处理 机器视觉这类课题对我这种高中没毕业的人 ...
- 基于 getter 和 setter 撸一个简易的MVVM
Angular 和 Vue 在对Angular的学习中,了解到AngularJS 的两个主要缺点: 对于每一次界面时间,Ajax 或者 timeout,都会进行一个脏检查,而每一次脏检查又会在内部循环 ...
- 探秘Tomcat——一个简易的Servlet容器
即便再简陋的服务器也是服务器,今天就来循着书本的第二章来看看如何实现一个servlet容器. 背景知识 既然说到servlet容器这个名词,我们首先要了解它到底是什么. servlet 相比你或多或少 ...
- 使用Windows Form 制作一个简易资源管理器
自制一个简易资源管理器----TreeView控件 第一步.新建project,进行基本设置:(Set as StartUp Project:View/Toolbox/TreeView) 第二步.开始 ...
- [后端人员耍前端系列]AngularJs篇:使用AngularJs打造一个简易权限系统
一.引言 上一篇博文已经向大家介绍了AngularJS核心的一些知识点,在这篇博文将介绍如何把AngularJs应用到实际项目中.本篇博文将使用AngularJS来打造一个简易的权限管理系统.下面不多 ...
- ENode 2.0 - 第一个真实案例剖析-一个简易论坛(Forum)
前言 经过不断的坚持和努力,ENode 2.0的第一个真实案例终于出来了.这个案例是一个简易的论坛,开发这个论坛的初衷是为了验证用ENode框架来开发一个真实项目的可行性.目前这个论坛在UI上是使用了 ...
- 使用MVVM框架avalon.js实现一个简易日历
最近在做公司内部的运营管理系统,因为与日历密切相关,同时无需触发条件直接显示在页面上,所以针对这样的功能场景,我就用avalon快速实现了一个简易日历,毕竟也是第一次造日历这种轮子,所以这里记录下我当 ...
随机推荐
- Python—后台运行(nohup 、&、 2>&1详解)
一.脚本文件(test.py) # -*- coding: UTF-8 -*- import time print("hello"," python") os. ...
- Tensorflow学习教程------读取数据、建立网络、训练模型,小巧而完整的代码示例
紧接上篇Tensorflow学习教程------tfrecords数据格式生成与读取,本篇将数据读取.建立网络以及模型训练整理成一个小样例,完整代码如下. #coding:utf-8 import t ...
- GetCharWidth32
#include <windows.h> #include<stdio.h> // 窗口函数的函数原形 LRESULT CALLBACK MainWndProc(HWND, U ...
- c语言删除文件的指定行,更新文件
有时候我们需要删除文件的某一行,来更新文件,在这我个人扩展了一个函数,以删除指定条件的行. static void UpdateHistoryFile(void) { FILE *fin,*fout; ...
- 输入一段汉字可以获得首字母简拼的java代码
package com.zl; import java.io.UnsupportedEncodingException; public class Test12 { public static voi ...
- tomcat设置远程监听端口(linux&windows)
1.Linxu系统: apach/bin/startup.sh开始处中增加如下内容: declare -x CATALINA_OPTS="-server -Xdebug -Xnoagent ...
- java package 包 学习笔记
编译命令示例: javac -d . Main.java 注:带参数-d自动建立文件目录, 只使用javac 则需要手工创建目录 把 class文件打包 jar命令 jar cvf T.jar *; ...
- debian8修改kde桌面语言
apt-get install kde-l10n-zhcn, language里面改中文 亲测可用 来源:http://tieba.baidu.com/p/2489771177
- [SDOI2019]世界地图(kruskal重构树+虚树)
通过子任务1.3十分显然,子任务4实际上就是线段树,和我下午写的[SDOI2015]道路修建一模一样,堪称“我抄我自己”,不会的可以先做一下这个题. 然后考虑正解,参考了zhoushuyu的博客,首先 ...
- http跳转http
server {listen 80;server_name 123.com;root /var/www/web/123;index index.html index.htm index.php;rew ...