C++链表与键值对
《算法》一书中,在算法3.1中提到了Map的实现,这里根据书上的思想,用单向链表简单写了写。
#ifndef SEQUENTIAL_H
#define SEQUENTIAL_H
template<class K, class V>
class Link
{
private:
class Node
{
public:
K key=;
V value=;
Node *next=nullptr;
public:
Node(K, V, Node*);
Node(){};
};
private:
Node *first;
int _length;
int _capicty;
public:
Link();
V& get(K key);
void put(K key, V value);
int Size() const;
int Capicty() const;
bool Delete(K key);
~Link();
};
template<class K, class V>
Link<K, V>::Node::Node(K key, V value, Node* node)
{
this->key = key;
this->value = value;
next = node;
}
template<class K, class V>
V& Link<K, V>::get(K key)
{
Node *x = first;
; i < _length&& x != nullptr; i++)
{
if (x->key == key) return x->value;
x = x->next;
}
}
//如果没有K,则在链表尾加入新的键值对
template<class K, class V>
void Link<K, V>::put(K key, V value)
{
Node *x = first;
bool flag = false;
; i < _length; i++)
{
if (x->key == key) { x ->value = value; flag = true; break; }
x = x->next;
}
if (!flag)
{
>= _capicty)
{
Node *m = first;
_capicty *= ;
Node **n = new Node*[_capicty];
; i < _capicty; i++)
{
n[i] = new Node();
}
; i < _capicty - ; i++)
{
n[i]->next = n[i + ];
}
; i < _capicty && m!=nullptr; i++)
{
n[i] = m;
m = m->next;
}
delete[] first;
first = n[];
}
int l = _length;
Node *y = first;
while (l)
{
y = y->next;
l--;
}
y->value = value;
y->key = key;
y->next = y->next;
_length++;
}
}
template<class K, class V>
Link<K, V>::~Link()
{
if (first != nullptr) delete[] first;
}
template<class K, class V>
Link<K, V>::Link()
{
Node** n = ];
_capicty = ;
_length = ;
; i < ; i++)
{
n[i] = new Node();
}
; i < -; i++)
{
n[i]->next = n[i+];
}
first = n[];
}
template<class K, class V>
int Link<K, V>::Size() const
{
return _length;
}
//当前链表容量
template<class K, class V>
int Link<K, V>::Capicty() const
{
return _capicty;
}
template<class K, class V>
bool Link<K, V>::Delete(K key)
{
bool flag = false;
Node* n = first->next;
Node* b = first;
if (b->key == key)
{
_length--;
first = first->next;
return true;
}
; i < _length; i++)
{
if (n->key == key)
{
b->next = n->next;
_length--;
flag = true;
break;
}
b = b->next;
n = n->next;
}
return flag;
}
#endif
C++链表与键值对的更多相关文章
- (转)C#中键值对类型Hashtable与Dictionary比较和相关用法
最近在使用C#中的Hashtable与Dictionary的时候,想知道其区别,通过查找网络相关博客资料,作出下列总结. Hashtable与Dictionary虽然都是作为键值对的载体,但是采用的是 ...
- 浅谈Redis数据库的键值设计(转)
丰富的数据结构使得redis的设计非常的有趣.不像关系型数据库那样,DEV和DBA需要深度沟通,review每行sql语句,也不像memcached那样,不需要DBA的参与.redis的DBA需要熟悉 ...
- JAVA中的数据结构——集合类(线性表:Vector、Stack、LinkedList、set接口;键值对:Hashtable、Map接口<HashMap类、TreeMap类>)
Java的集合可以分为两种,第一种是以数组为代表的线性表,基类是Collection:第二种是以Hashtable为代表的键值对. ... 线性表,基类是Collection: 数组类: person ...
- 从源码看HashMap键值对集合
之前我们看过了两种类型的集合,ArrayList集合和LinkedList集合,两种集合各有优势,我们不具体说了,但是本篇要看的集合可以完成它们完成不了的任务.比如:现有一篇文章,要你统计其中出现了哪 ...
- [Redis]Redis的五种数据类型与键值/服务器相关命令
-------------------------------------------------------------------------------------- String(字符串):最 ...
- 数据结构(一): 键值对 Map
Map基本介绍 Map 也称为:映射表/关联数组,基本思想就是键值对的关联,可以用键来查找值. Java标准的类库包含了Map的几种基本的实现,包括:HashMap,TreeMap,LinkedHas ...
- redis基础之基本键值操作和使用(三)
前言 redis安装完毕后开始使用redis,先熟悉命令行操作. redis数据的类型 键:redis的所有的键都是string类型: 值:五种类型 string:字符串类型:一个string最大可以 ...
- [19/03/26-星期二] 容器_Map(图、键值对、映射)接口之HashMap(散列映射)&TreeMap(树映射)
一.概念&方法 现实生活中,我们经常需要成对存储某些信息.比如,我们使用的微信,一个手机号只能对应一个微信账户,这就是一种成对存储的关系. Map就是用来存储“键(key)-值(value) ...
- 浅谈REDIS数据库的键值设计(转)
add by zhj: 关系数据库表的一条记录可以映射成Redis中的一个hash类型,其实数据库记录本来就是键值对.这样,要比本文中的键设计用更少的键,更节省内存,因为每个键除了它的键值占用内存外, ...
随机推荐
- struts文件上传拦截器中参数的配置(maximumSize,allowedTypes ,allowedExtensions)问题
<interceptor-ref name="fileUpload"> <param name="allowedTypes">image ...
- git实现版本回退
1. 首先查看自己的版本: ***:~/piaoshifu_object/epiao.piaoshifu.cn$ git log commit c8d5c67861d2d0e21856cc2b4f60 ...
- matlab的cell数组
matlab的cell数组 元胞数组: 元胞数组是MATLAB的一种特殊数据类型,可以将元胞数组看做一种无所不包的通用矩阵,或者叫做广义矩阵.组成元胞数组的元素可以是任何一种数据类型的常数或者常量,每 ...
- socket、tcp、http
第一部分.概念的理解 1.什么是Socket? Socket又称之为“套接字”,是系统提供的用于网络通信的方法.它的实质并不是一种协议,没有规定计算机应当怎么样传递消息,只是给程序员提供了一个发送消息 ...
- 【HDU4552】 怪盗基德的挑战书(后缀数组)
怪盗基德的挑战书 Problem Description “在树最美丽的那天,当时间老人再次把大钟平均分开时,我会降临在灯火之城的金字塔前,带走那最珍贵的笑容.”这是怪盗基德盗取巴黎卢浮宫的<蒙 ...
- 去大公司还是去小公司工作——要进大公司的核心部门(提升视野,锻炼技能),远离没真本事的小公司,要自我驱动 good
去大公司还是小公司工作?这个问题问大多数 IT 人都会选择前者.如果换一个问法,去大公司还是去初创公司(Startup)工作?或许有极小一部分人能改变一下决定 对于 IT 人来说,选择到大公司工作的理 ...
- app.config应该放哪?
一:做了一个简单的三层构架的小例子,在主项目里调用工具类的方法实现在数据库里添加一条信息.先看下错误的提示信息是什么样的,如下图一,图二是调用工具类.直接在工具类里写上连接字符串就没问题,如果写到ap ...
- Win32消息机制
1. 消息机制 过程驱动:程序是按照我们预先定义好的顺序执行,每执行一步,下一步都已经按照预定的顺序继续执行,直到程序结束. 事件驱动:程序的执行顺序是无序的.某个时间点所执行的代 ...
- POJ 1159 Palindrome 最长公共子序列的问题
Description A palindrome is a symmetrical string, that is, a string read identically from left to ri ...
- HDU 2089 不要62(挖个坑=-=)
不要62 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...