2018-04-18 20:36:51 +08:00
|
|
|
//
|
2018-04-17 16:42:30 +08:00
|
|
|
#include<iostream>
|
|
|
|
#include<math.h>
|
|
|
|
using namespace std;
|
2018-04-18 20:36:51 +08:00
|
|
|
|
|
|
|
struct Node {
|
2018-04-17 16:42:30 +08:00
|
|
|
int data;
|
2018-04-18 20:36:51 +08:00
|
|
|
struct Node *next;
|
2018-04-17 16:42:30 +08:00
|
|
|
} *head[100],*curr;
|
|
|
|
|
2018-04-18 20:36:51 +08:00
|
|
|
void init() {
|
2018-04-17 16:42:30 +08:00
|
|
|
for(int i=0;i<100;i++)
|
|
|
|
head[i]=NULL;
|
|
|
|
}
|
|
|
|
|
2018-04-18 20:36:51 +08:00
|
|
|
void add(int x,int h) {
|
|
|
|
struct Node *temp = new Node;
|
2018-04-17 16:42:30 +08:00
|
|
|
temp->data = x;
|
|
|
|
temp->next = NULL;
|
2018-04-18 20:36:51 +08:00
|
|
|
if(!head[h]) {
|
2018-04-17 16:42:30 +08:00
|
|
|
head[h] = temp;
|
2018-04-18 20:36:51 +08:00
|
|
|
curr = head[h];
|
2018-04-17 16:42:30 +08:00
|
|
|
}
|
2018-04-18 20:36:51 +08:00
|
|
|
else {
|
2018-04-17 16:42:30 +08:00
|
|
|
curr=head[h];
|
2018-04-18 20:36:51 +08:00
|
|
|
while(curr->next)
|
|
|
|
curr = curr->next;
|
2018-04-17 16:42:30 +08:00
|
|
|
curr->next = temp;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-04-18 20:36:51 +08:00
|
|
|
void display(int mod) {
|
|
|
|
struct Node *temp;
|
2018-04-17 16:42:30 +08:00
|
|
|
int i;
|
2018-04-18 20:36:51 +08:00
|
|
|
for(i=0;i<mod;i++) {
|
|
|
|
if(!head[i]) {
|
|
|
|
cout<<"Key "<<i<<" is empty"<<endl;
|
2018-04-17 16:42:30 +08:00
|
|
|
}
|
2018-04-18 20:36:51 +08:00
|
|
|
else {
|
|
|
|
cout<<"Key "<<i<<" has values = ";
|
2018-04-17 16:42:30 +08:00
|
|
|
temp = head[i];
|
2018-04-18 20:36:51 +08:00
|
|
|
while(temp->next) {
|
2018-04-17 16:42:30 +08:00
|
|
|
cout<<temp->data<<" ";
|
|
|
|
temp=temp->next;
|
|
|
|
}
|
|
|
|
cout<<temp->data;
|
|
|
|
cout<<endl;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-04-18 20:36:51 +08:00
|
|
|
int hash(int x,int mod) {
|
2018-04-17 16:42:30 +08:00
|
|
|
return x%mod;
|
|
|
|
}
|
|
|
|
|
2018-04-18 20:36:51 +08:00
|
|
|
void find(int x,int h) {
|
|
|
|
struct Node *temp =head[h];
|
|
|
|
if(!head[h]) {
|
2018-04-17 16:42:30 +08:00
|
|
|
cout<<"Element not found";
|
|
|
|
return;
|
|
|
|
}
|
2018-04-18 20:36:51 +08:00
|
|
|
while(temp->data !=x && temp->next)
|
2018-04-17 16:42:30 +08:00
|
|
|
temp=temp->next;
|
2018-04-18 20:36:51 +08:00
|
|
|
if(temp->next)
|
2018-04-17 16:42:30 +08:00
|
|
|
cout<<"Element found";
|
|
|
|
else{
|
2018-04-18 20:36:51 +08:00
|
|
|
if(temp->data == x)
|
2018-04-17 16:42:30 +08:00
|
|
|
cout<<"Element found";
|
|
|
|
else
|
2018-04-18 20:36:51 +08:00
|
|
|
cout<< "Element not found";
|
2018-04-17 16:42:30 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-04-18 20:36:51 +08:00
|
|
|
int main(void) {
|
2018-04-17 16:42:30 +08:00
|
|
|
init();
|
2018-04-18 20:36:51 +08:00
|
|
|
int c,x,mod,h;
|
2018-04-17 16:42:30 +08:00
|
|
|
cout<<"Enter the size of Hash Table. = ";
|
|
|
|
cin>>mod;
|
2018-04-18 20:36:51 +08:00
|
|
|
bool loop = true;
|
|
|
|
while(loop) {
|
2018-04-17 16:42:30 +08:00
|
|
|
cout<<endl;
|
|
|
|
cout<<"PLEASE CHOOSE -"<<endl;
|
|
|
|
cout<<"1. Add element."<<endl;
|
|
|
|
cout<<"2. Find element."<<endl;
|
|
|
|
cout<<"3. Generate Hash."<<endl;
|
|
|
|
cout<<"4. Display Hash table."<<endl;
|
|
|
|
cout<<"5. Exit."<<endl;
|
|
|
|
cin>>c;
|
2018-04-18 20:36:51 +08:00
|
|
|
switch(c) {
|
|
|
|
case 1:
|
2018-04-17 16:42:30 +08:00
|
|
|
cout<<"Enter element to add = ";
|
|
|
|
cin>>x;
|
2018-04-18 20:36:51 +08:00
|
|
|
h = hash(x,mod);
|
|
|
|
h = fabs(h);
|
2018-04-17 16:42:30 +08:00
|
|
|
add(x,h);
|
|
|
|
break;
|
2018-04-18 20:36:51 +08:00
|
|
|
case 2:
|
2018-04-17 16:42:30 +08:00
|
|
|
cout<<"Enter element to search = ";
|
|
|
|
cin>>x;
|
2018-04-18 20:36:51 +08:00
|
|
|
h = hash(x,mod);
|
2018-04-17 16:42:30 +08:00
|
|
|
find(x,h);
|
|
|
|
break;
|
2018-04-18 20:36:51 +08:00
|
|
|
case 3:
|
2018-04-17 16:42:30 +08:00
|
|
|
cout<<"Enter element to generate hash = ";
|
|
|
|
cin>>x;
|
|
|
|
cout<<"Hash of "<<x<<" is = "<<hash(x,mod);
|
|
|
|
break;
|
2018-04-18 20:36:51 +08:00
|
|
|
case 4:
|
2018-04-17 16:42:30 +08:00
|
|
|
display(mod);
|
|
|
|
break;
|
2018-04-18 20:36:51 +08:00
|
|
|
default:
|
|
|
|
loop = false;
|
|
|
|
break;
|
2018-04-17 16:42:30 +08:00
|
|
|
}
|
|
|
|
cout<<endl;
|
|
|
|
}
|
|
|
|
/*add(1,&head1);
|
|
|
|
add(2,&head1);
|
|
|
|
add(3,&head2);
|
|
|
|
add(5,&head1);
|
|
|
|
display(&head1);
|
|
|
|
display(&head2);*/
|
|
|
|
return 0;
|
|
|
|
}
|