码迷,mamicode.com
首页 > 编程语言 > 详细

C++链表与键值对

时间:2016-11-22 20:15:57      阅读:470      评论:0      收藏:0      [点我收藏+]

标签:思想   实现   put   void   pre   next   ict   单向链表   code   

《算法》一书中,在算法3.1中提到了Map的实现,这里根据书上的思想,用单向链表简单写了写。

#ifndef SEQUENTIAL_H
#define SEQUENTIAL_H
template<class K, class V>
class Link
{
private:
    class Node
    {
    public:
        K key=0;
        V value=0;
        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;
    for (int i = 0; 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;
    for (int i = 0; i < _length; i++)
    {
        if (x->key == key) { x ->value = value; flag = true; break; }
        x = x->next;
    }
    if (!flag)
    {
        if (_length+1 >= _capicty)
        {
            Node *m = first;
            _capicty *= 2;
            Node **n = new Node*[_capicty];
            for (int i = 0; i < _capicty; i++)
            {
                n[i] = new Node();
            }
            for (int i = 0; i < _capicty - 1; i++)
            {
                n[i]->next = n[i + 1];
            }
            for (int i = 0; i < _capicty && m!=nullptr; i++)
            {
                n[i] =  m;
                m = m->next;
            }
            delete[] first;
            first = n[0];
        }        
        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 = new Node*[10];
    _capicty = 10;
    _length = 0;
    for (int i = 0; i <  10; i++)
    {
        n[i] = new Node();
    }
    for (int i = 0; i < 10-1; i++)
    {
        n[i]->next = n[i+1];
    }
    first = n[0];
}
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;
    }
    for (int i = 1; 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++链表与键值对

标签:思想   实现   put   void   pre   next   ict   单向链表   code   

原文地址:http://www.cnblogs.com/wzxwhd/p/6090679.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!