File: HashString.hpp

package info (click to toggle)
criticalmass 1%3A1.0.0-1.5
  • links: PTS
  • area: main
  • in suites: wheezy
  • size: 18,740 kB
  • sloc: ansic: 47,628; cpp: 25,167; sh: 12,025; xml: 3,532; perl: 3,271; makefile: 662; python: 66; awk: 40; lisp: 33
file content (49 lines) | stat: -rw-r--r-- 1,328 bytes parent folder | download | duplicates (11)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
// Description:
//   Hash functions for strings.
//
// Copyright (C) 2001 Frank Becker
//
// This program is free software; you can redistribute it and/or modify it under
// the terms of the GNU General Public License as published by the Free Software
// Foundation;  either version 2 of the License,  or (at your option) any  later
// version.
//
// This program is distributed in the hope that it will be useful,  but  WITHOUT
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
// FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details
//
#ifndef _HashString_hpp_
#define _HashString_hpp_

#include <hashMap.hpp>
#include <string>
using namespace std;

namespace HASH_NAMESPACE
{
    template<>
	struct hash<const string>
    {
	//a simple hash function for string
	int operator()(const string & s) const
	{
	    int hashval = 13*(int)s.size() + 5*s[(int)s.size()/2];
    //        cout << "  > Hash of " << s << " = " << hashval << endl;
	    return hashval;
	}
    };

    template<>
	struct hash<string>
    {
	//a simple hash function for string
	int operator()(string s) const
	{
	    int hashval = 13*(int)s.size() + 5*s[(int)s.size()/2];
    //        cout << "  > Hash of " << s << " = " << hashval << endl;
	    return hashval;
	}
    };

} //namespace std
#endif