Tuesday, July 28, 2009

Can anyone help me with this C programming problem?

It's like this. Using C programming, we were told to make a phonebook where we can add entries, sort by first name, sort by last name, and delete entries. It should also contain the name, address, telephone number and mobile number. Our teacher told us to use data structures. The thing is, we never got that far in our discussion in class, and we are supposed to pass this on October 9. We're working on the program now, but help is really appreciated...Thanks in advance! :D

Can anyone help me with this C programming problem?
this might help, just need some addition and revision, at least you know the logic how to create it.








#include %26lt;ctype.h%26gt;


#include %26lt;string.h%26gt;


#include %26lt;io.h%26gt;


#include %26lt;conio.h%26gt;


#define PHONE_MIN 7


// the info structure





struct strc{


int id;


char name[20];


char address[25];


char phone[20];


}info;





void getentry();


void putentry(int);


void delentry(int);


int countentry();


int readentry(int,int);


void searchentry();


int main(void)








{


register char ch;


register int sz;


int id;


char intr[]="################################...


"## Insert Entry (I) || call by ID (C) || See All (A)#\n"


"## Edit Entry (T) || delete (D) || search (S) || Exit (X) #\n"


"#####################################...


//Inserting the Main Menu


puts(intr);








do{


ch=toupper(ch=getch());


fflush(stdin);


switch(ch)








{


case 'I':


//Inserting a new Entry


printf("Inserting Entry Number: %d\n", (countentry()+1));


//Get the new Entry from the user


getentry();


//Insert that entry in the file


putentry(0);


puts("Done");


puts(intr);


break;


case 'C':


//Calling an entry by its ID


//checking if we have the file


if(!(sz=countentry()))








{


puts("Couldn't find the entry file");


puts(intr);


break;


}


//getting the entry ID which should be not greater than the entries total


printf("You have %d Entries\n", countentry());


puts("Enter the ID of your entry");








do{


scanf("%d", %26amp;id);


fflush(stdin);


if(id%26gt;sz) printf("You have only %d entries\ntry again\n", sz);


}while(id%26gt;sz);


//showing the chosen entry


puts("+---+----------------------+---...


printf("|ID | %-20s| %-25s| %-20s|\n", "NAME","ADDRESS","PHONE #");


readentry(id,1);


puts("+---+----------------------+---...


puts("Done");


puts(intr);


break;


case 'A':


//showing all the entries


//checking if we have the file


if(!(sz=countentry()))








{


puts("Couldn't find the entry file");


puts(intr);


break;


}


//showing all entries


puts("Displaying All Entries");


puts("+---+----------------------+---...


printf("|ID | %-20s| %-25s| %-20s|\n", "NAME","ADDRESS","PHONE #");


for(id=1; id%26lt;=sz ; id++)








{


readentry(id,1);


//pause every 20 entries


if(id==20)








{


puts("+---+----------------------+-...


puts("Press any key to continue..");


getch();


}


}


puts("+---+----------------------+---...


puts("Done");


puts(intr);


break;


case 'T':


//editing an entry


//checking if we have the file


if(!(sz=countentry()))








{


puts("Couldn't find the entry file");


puts(intr);


break;


}


puts("Editing Entry");


puts("Enter ID of your entry");


//getting the entry ID which should be not greater than the entries total








do{


scanf("%d", %26amp;id);


fflush(stdin);


if(id%26gt;sz) printf("You have only %d entries\ntry again\n", sz);


}while(id%26gt;sz);


//diplaying the entry


puts("+---+----------------------+---...


printf("|ID | %-20s| %-25s| %-20s|\n", "NAME","ADDRESS","PHONE #");


readentry(id,1);


puts("+---+----------------------+---...


//Get the new Entry from the user


getentry();


//Insert that entry in the file in the same place


putentry(id);


puts("Done");


puts(intr);


break;


case 'D':


//Deleting an entry


//checking if we have the file


if(!(sz=countentry()))








{


puts("Couldn't find the entry file");


puts(intr);


break;


}


puts("Deleting Entry");


puts("Enter ID of your entry");


//getting the entry ID which should be not greater than the entries total








do{


scanf("%d", %26amp;id);


fflush(stdin);


if(id%26gt;sz) printf("You have only %d entries\ntry again\n", sz);


}while(id%26gt;sz);


//diplaying the entry


puts("+---+----------------------+---...


printf("|ID | %-20s| %-25s| %-20s|\n", "NAME","ADDRESS","PHONE #");


readentry(id,1);


puts("+---+----------------------+---...


//deleting


delentry(id);


puts("Done");


puts(intr);


break;


case 'S':


//Searching for an entry


//checking if we have the file


if(!(sz=countentry()))








{


puts("Couldn't find the entry file");


puts(intr);


break;


}


//searching


searchentry();


puts(intr);


break;


case 'X':


//Exit


printf("%c\n",ch);


printf("Ending...\n\n");


default:


;


}


}while(ch!='X');


return 0;


}





//getting the user's input


void getentry()








{


register int i;


//using fgets to get the user's input


//so we avoud the array overflow


puts("Full Name:");


fgets(info.name, 20, stdin);


//must flush the input stream before useing fgets again


fflush(stdin);


//checking if the user passed this input


if(info.name[0]=='\n') info.name[0]='\0';


//removing the newline from the string


else strtok(info.name, "\n");


puts("address:");


fgets(info.address, 25, stdin);


fflush(stdin);


if(info.address[0]=='\n') info.address[0]='\0';


else strtok(info.address, "\n");








do{


puts("phone #:");


fgets(info.phone, 20, stdin);


fflush(stdin);


//user must enter some number


if(info.phone[0]=='\n') puts("You should enter a phone #");








else {


strtok(info.phone,"\n");


//the number shouldn't contain characters


for(i=0;info.phone[i];i++)


if(!isdigit(info.phone[i]))








{


puts("You can only enter digits");


info.phone[0]='\n';


break;


};


//the number is less than 7 numbers


if(i%26lt;PHONE_MIN %26amp;%26amp; info.phone[0]!='\n')








{


puts("The Phone # should contain more than 6 digits");


info.phone[0]='\n';


}


}


}while(info.phone[0]=='\n');


//getting the entry id


if(info.id=countentry()) info.id++;


else info.id=1;


}





//inserting the entry to the file


void putentry(register int id)








{


FILE* fp;


register int sz;


//checking if the file exists


if(!(sz=countentry()))








{


//creat one and close it


fp=fopen("list.phn", "a");


fclose(fp);


id=1;


}


//open it again for binary reading and writing


if(!(fp=fopen("list.phn", "r+b")))


puts("Couldn't find the entry file");


else





{


if(id)








{


//if we have and id so we're editing an entry


//so we need to seek to the same place


info.id=id;


fseek(fp, --id*sizeof(struct strc), SEEK_SET);


}else fseek(fp, sz*sizeof(struct strc), SEEK_SET);//we don't have id seek to end


//writing the structure


fwrite(%26amp;info, sizeof(struct strc), 1, fp);


fclose(fp);


}


}





//that's for checking the if the file ex


// ists and return the number of entires


int countentry()








{


FILE* fp;


register int sz;


//opening binary readonly


if(!(fp=fopen("list.phn", "rb")))


return 0;








else{


//dividing the file size over the size of the structure


//to get the total


sz=filelength(fileno(fp));


sz=sz/sizeof(struct strc);


fclose(fp);


return sz;


}


}





//read the entry by its id and displayin


// g result on demand


int readentry(register int id,register int display)








{


FILE* fp;


//opening binary readonly


if(!(fp=fopen("list.phn", "rb")))


return 0;








else{


//if we have an id seek to it


if(id%26gt;1) fseek(fp, --id*sizeof(struct strc), SEEK_SET);


fread(%26amp;info, sizeof(struct strc), 1, fp);


//if we need to print the result


if(display)








{


puts("+---+----------------------+---...


printf("|%-3d| %-20s| %-25s| %-20s|\n", info.id,info.name,info.address,info.phon...


}


fclose(fp);


return id;


}


}





//deleting the file


void delentry(register int id)








{


FILE* tmpfp;


register int sz=countentry(), i, j;


char in;


//make sure user wants to delete


puts("are you sure you want to delete?");


in=toupper(in=getchar());


fflush(stdin);


if(in=='N')








{


puts("Entry wasn't removed");


return;


}


puts("YES");


//creating a temp file


tmpfp=tmpfile();


//coping all entries from the phonebook file


//to the temp file except for the deleted one


for(i=1,j=1; i%26lt;=sz;i++)








{


readentry(i,0);


//passing the deleted entry and inserting a new id=j


if(i!=id)








{


info.id=j;


fwrite(%26amp;info, sizeof(struct strc), 1, tmpfp);


j++;


}


}


//seeking to the beginning of the file


rewind(tmpfp);


//deleting the old phonebook file


remove("list.phn");


//coping the entries from the temp file to the new phonebook file


for(id=1;id%26lt;j;id++)








{


fread(%26amp;info, sizeof(struct strc), 1, tmpfp);


putentry(id);


}


puts("Entry deleted successfully");


_rmtmp();


}





//searching the phonebook


void searchentry()








{


register char ch;


char key[25], *result, search_str[100];


register int i, id, sz=countentry();


//Which part user likes to search


puts("Do you like to search by NAME:(N),or ADDRESS:(A),or PHONE#(P)?");








do{


ch=toupper(ch=getchar());


fflush(stdin);


}while(ch!='N' %26amp;%26amp; ch!='A' %26amp;%26amp; ch!='P');


//getting the searvh string


puts("Enter your search:");


strtok(fgets(search_str, 100, stdin),"\n");


fflush(stdin);


//starting our search


for(id=1, i=1; id%26lt;=sz; id++)








{


//loading current entry inside our structure


readentry(id,0);


//what are we going to search


switch (ch)








{


case 'N': strcpy(key,info.name); break;


case 'A': strcpy(key,info.address); break;


case 'P': strcpy(key,info.phone); break;


default : ;


}


//checking the current string


result=strstr(strlwr(key), strlwr(search_str));


if(result)








{


//we found an Entry %26amp; printing it


if(i==1)








{


printf("The Entries containing \"%s\" are :\n", search_str);


puts("+---+----------------------+--...


printf("|ID | %-20s| %-25s| %-20s|\n", "NAME","ADDRESS","PHONE #");


//pause every 20 result


}


readentry(id,1);


if(i==20)








{


puts("+---+----------------------+-...


puts("Press any key to continue..");


getch();


}


i++;


}


}


if(--i)








{


//inserting footer for ending our search


puts("+---+----------------------+----...


printf("Found %d Result\n", i);


}else


//didn't find any


puts("No Results found");


}
Reply:Its better taking your teacher's help instead of checking all people's answers and deciding which one will suit you








BEST OF LUCK
Reply:If your teacher has office hours available where you can go over the project one-on-one, I highly suggest you take advantage of it.
Reply:U can do this using single linked list... its not very tough however takes time to write down the answer..


I have a program that takes,,,,name, address and roll number .... and this porgram can


1) add entries


2) delete entries


3) search entries


4) modify entries


5) traverse list





If u want i can post it here and u can make little bit of updations.. lemme know





/*Program for single linked list in c*/


#include%26lt;stdio.h%26gt;


#include%26lt;malloc.h%26gt;


struct list


{


char name[25];


char roll[4];


char addr[25];


struct list *next;


}*start;


struct list *search();


main()


{


char code[4],ch=' ';


struct list *ptr;


clrscr();


while(ch!='6')


{


printf("\n\n1. add items");


printf("\n2. modify items");


printf("\n3. search items");


printf("\n4. delete items");


printf("\n5. display items");


printf("\n6. exit");


printf("\n\nenter ur choice\n");


scanf("%c",%26amp;ch);


fflush(stdin);


if(ch=='1')


{


add();


}


if(ch=='2')


{


mod();


}


if(ch=='3')


{


printf("\nEnter the roll no to be searched for\n");


scanf("%s",%26amp;code);


fflush(stdin);


ptr=search(code);


if(ptr)


{


printf("\nThe roll no is %s",ptr-%26gt;roll);


printf("\nThe name is %s",ptr-%26gt;name);


printf("\nThe address is %s",ptr-%26gt;addr);


}


else


{


printf("\nThe roll no does not exists\n");


}


}


if(ch=='4')


{


del();


}


if(ch=='5')


{


display();


}


if(ch=='6')


{


exit();


}


else


{


continue;


}


}


}


struct list *getdata()


{


struct list *new;


new=(struct list *)malloc(sizeof(struct list));


printf("\nEnter the name\n");


scanf("%s",new-%26gt;name);


fflush(stdin);


printf("\nEnter the roll no\n");


scanf("%s",new-%26gt;roll);


fflush(stdin);


printf("\nEnter the address\n");


scanf("%s",new-%26gt;addr);


fflush(stdin);


return new;


}


add()


{


struct list *ptr,*prev,*new;


new=getdata();


if(start==NULL)


{


start=new;


new-%26gt;next=NULL;


return;


}


for(ptr=start;(ptr)%26amp;%26amp;strcmp(new-%26gt;roll...


if(strcmp(new-%26gt;roll,ptr-%26gt;roll)==0)


{


printf("\nThe roll no already exists\n");


return;


}


if(ptr!=start)


{


prev-%26gt;next=new;


new-%26gt;next=ptr;


}


else


{


new-%26gt;next=start;


start=new;


}


}


mod()


{


struct list *ptr;


char code[4];


printf("\nEnter the roll no\n");


scanf("%s",code);


ptr=search(code);


if(ptr==NULL)


{


printf("\nThe roll no does not exists\n");


return;


}


printf("\nEnter the address\n");


scanf("%s",ptr-%26gt;addr);


fflush(stdin);


}


struct list *search(char *s)


{


struct list *ptr;


for(ptr=start;(ptr)%26amp;%26amp;strcmp(s,ptr-%26gt;ro...


if(strcmp(s,ptr-%26gt;roll)==0)


{


return ptr;


}


else


{


return NULL;


}


}


del()


{


struct list *prev,*ptr;


char code[4];


printf("\nEnter the roll to be deleted\n");


scanf("%s",code);


fflush(stdin);


for(ptr=start;(ptr)%26amp;%26amp;strcmp(code,ptr-...


{


prev=ptr;


ptr=ptr-%26gt;next;


}


if(!ptr) /*valid if ptr==null*/


{


printf("\nThe roll no does not exists\n");


return;


}


if(ptr==start)


{


start=ptr-%26gt;next;


free(ptr);


return;


}


prev-%26gt;next=ptr-%26gt;next;


free(ptr);


return;


}


display()


{


struct list *ptr;


for(ptr=start;(ptr);ptr=ptr-%26gt;next)


{





printf("\n\nThe roll no is %s",ptr-%26gt;roll);


printf("\nThe name is %s",ptr-%26gt;name);


printf("\nThe address is %s",ptr-%26gt;addr);


}


}
Reply:You are going to have to use arrays, to store the information,


First read about Arrays!!!! You may also need to know something about pointers. I will help u wen i get time.
Reply:Does not look easy. May be you can contact a C programming expert at websites like http://oktutorial.com/


No comments:

Post a Comment