aboutsummaryrefslogtreecommitdiff
path: root/tests/hashtest.cpp
blob: fefb6cc37a9d536a009fa4b262734677acd855b0 (plain)
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
//#include <iostream>
#include <stdio.h>
#include <map>
#include <cstring>

using namespace std;

struct ltstr
{
  bool operator()(const char* s1, const char* s2) const
  {
    return strcmp(s1, s2) < 0;
  }
};

int main()
{
  map<const char*, int, ltstr> months;
  
  months["january"] = 31;
  months["february"] = 28;
  months["march"] = 31;
  months["april"] = 30;
  months["may"] = 31;
  months["june"] = 30;
  months["july"] = 31;
  months["august"] = 31;
  months["september"] = 30;
  months["october"] = 31;
  months["november"] = 30;
  months["december"] = 31;
  
  //cout << "june -> " << months["june"] << endl;
  printf("june -> %d\n", months["june"]);
  map<const char*, int, ltstr>::iterator cur  = months.find("june");
  map<const char*, int, ltstr>::iterator prev = cur;
  map<const char*, int, ltstr>::iterator next = cur;    
  ++next;
  --prev;
  //cout << "Previous (in alphabetical order) is " << (*prev).first << endl;
  //cout << "Next (in alphabetical order) is " << (*next).first << endl;
  printf("Previous (in alphabetical order) is %s\n", (*prev).first);
  printf("Next (in alphabetical order) is %s\n", (*next).first);
}