c语言手机通讯录程序啊~小弟初来,分数不高,望各位高手给指点指点吧!!!

1、数据结构描述
1)程序设计中要求至少使用以下的数据结构:
①基本类型数据;
②数组类型;
③指针类型;
④结构体类型;
⑤文件类型。
2)必备的数据结构说明如下:
①符号常量:N最大记录数200;
②定义结构体类型标识符ADDRESS,用来定义该类型的结构体变量、数组和指针,该结构体包括以下数据成员:
char name[9]; /*姓名*/
char sex[3]; /*性别*/
int age; /*年龄*/
char tele[3][13]; /*电话,包括:家庭、单位、手机*/
char group[5]; /*分组,包括:家人、同事、同学、朋友、其他等*/
char address[40]; /*联系地址*/
char postalcode[7]; /*邮政编码*/
③4个外部变量:
temp[N]:为ADDRESS类型的结构体数组,用来存放从数据文件address.dat中读出的记录,以便各函数使用;
field[9][11]={"姓名","性别","年龄","家庭电话","单位电话","手机","关系","联系地址","邮政编码"}:为二维字符数组,用于记录输入、添加、修改、删除等操作的信息提示;
relation[5][5]={"家人","同事","同学","朋友","其他"}:为二维字符数组,用于记录输入、添加、修改等操作的选择项提示;
piece:为int类型的计数器,用来记录记录数,可供各函数使用。
2、系统总体功能
(手机)通讯录管理系统应具备以下功能:
①系统初始化:显示欢迎语:“欢迎使用通讯录管理系统!”和“按任意键系统开始初始化,显示通讯录!”,完成将从数据文件address.dat中读出的记录送入结构体数组temp(如果该文件中不存在记录,要求用户输入),以便程序运行过程中由其他函数使用;显示通讯录;返回通讯录含记录的条数;

3、系统中使用的各函数说明。
⑴初始化函数int initializtion(void)仅由主函数调用;
⑵输入记录函数int enter(void)仅由初始化函数调用;
⑶查找函数int seek(char same[])
⑷输入一条记录函数void input(ADDRESS *p)
⑸分屏显示记录函数void list(void)
⑹显示一条记录函数void type(ADDRESS *p)
⑺添加记录函数void append(void)
⑻修改记录函数void update(void)
⑼删除记录函数void dele(void)
⑽建立排序文件函数void createsortfile(ADDRESS temp1[],int n)
⑾显示按姓名排序函数void sortname(void)
⑿按姓名查询记录函数void findname(void)
⒀快速查询记录函数void quicksearch(void)
⒁主菜单函数int menuselect(void)如下:
********************菜 单********************
* 0.显示通讯录 *
* 1.添加记录 *
* 2.修改记录 *
* 3.删除记录 *
* 4.按姓名排序 *
* 5.按姓名查询 *
* 6.快速查询 *
* 7.退出 *
*********************************************
提示用户进行选择(编号),如果选择错误要求重新选择,选择正确提示确认,如果用户确认选错了,再重新选择,如果用户确认是选该项,返回主函数,去执行相应的功能,仅由主函数调用;
⒂退出系统函数void quit(void):将记录数据写入磁盘文件,显示结束语:“欢迎再次使用通讯录管理系统,再见!”,等待用户按键(用户按键不显示)退出系统;
⒃主函数void main(void):调用初始化函数,显示提示:“请按菜单选择要进行的操作,按任意键开始。”,等待用户按键(用户按键不显示),按主菜单函数的返回值,调用相应的函数。

这也要求貌似太多了
我这刚做了个简单的一点的通讯录
希望对LZ又点帮助
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<conio.h>
typedef struct//表示数据类型,可类比int
{
char name[15];
char city[15];
char telenub[15];//固定电话号码
char email[20];
char qq[13];
char youbian[10];//表示邮编
}DataType;

FILE *fp;
typedef struct node{//结类型定义
DataType data;//节点数据域
struct node * next;//节点指针域
}ListNode;
typedef ListNode * LinkList;
LinkList head;
ListNode *p;
//函数说明
void myprint();
LinkList CreateList();
void InsertNode(LinkList head,ListNode *p);
ListNode * ListFind(LinkList head);
void DelNode(LinkList head);
void PrintList(LinkList head);

//用尾插法建立通讯录链表函数
LinkList CreateList()
{
LinkList head=(ListNode *)malloc(sizeof(ListNode));//申请头结点 分配存储空间
ListNode *p,*rear;
int flag=0;//结束标志置0
rear=head;//尾指针初始指向头结点
if((fp=fopen("record.txt","w+"))==NULL) //打开文件,并判断打开是否正常
{
printf("打开文件失败!!\n");//没打开
exit(0); //退出
}
fprintf(fp,"%-15s%-20s%-15s%-20s%-10s%-12s\n","姓名","城市","电话","邮箱","QQ","邮编" );
while(flag==0)
{
p=(ListNode *)malloc(sizeof(ListNode));//申请新结点
printf(" 姓名 地址(城市) 电话 邮箱 QQ 邮编 \n");
scanf("%s%s%s%s%s%s",p->data.name ,p->data.city ,p->data.telenub ,p->data.email,p->data.qq,p->data.youbian );
fprintf(fp,"%-15s%-20s%-15s%-20s%-10s%-12s\n",p->data.name ,p->data.city ,p->data.telenub ,p->data.email,p->data.qq,p->data.youbian );
// fclose(fp);
rear->next=p;//新结点连接到尾结点之后
rear=p;//尾指针指向新结点

printf("是否结束建表?(1/0):");
scanf("%d",&flag);//读入一个标志数据

}
rear->next=NULL;//终端结点指针域置空
return head;//返回链表头指针
}

//在通讯录链表head中插入节点
void InsertNode(LinkList head,ListNode *p)
{
ListNode *p1,*p2;
p1=head;
p2=p1->next;

while(p2!=NULL&&strcmp(p2->data.name,p->data.name)<0)
{
p1=p2;//p1指向刚访问过的结点
p2=p2->next;//p2指向表的下一个结点
}
p1->next=p;//插入p所指向的的结点
p->next=p2;//连接表中剩余部分
}

//有序通讯录链上的查找

ListNode *ListFind(LinkList head)
{
ListNode *p;
char telenub[13];
char name[15];
int temp;
printf("请选择按姓名或电话查询(1/2):\n");
p=head->next;//假定通讯录表带头结点
scanf("%d",&temp);
if(temp==1)
{
printf("请输入要查找者的姓名");
scanf("%s",name);
while(p&&strcmp(p->data.name,name)!=0)
p=p->next;
if(p==NULL||strcmp(p->data.name,name)>0)
p=NULL;//没有查到要查找的姓名
}
else
if(temp==2){
printf("请输入要查找的电话号码:\n");
scanf("%s",telenub);
while(p&&strcmp(p->data.telenub,telenub)<0)
p=p->next;
if(p==NULL||strcmp(p->data.telenub,telenub)>0)
p=NULL;
}
return p;
}

//通讯录链表上结点的删除
//先调用查询函数,查询到要删除的结点,删除结点即可。
void DelNode(LinkList head)
{
char temp;
ListNode *p,*q;
p=ListFind(head);//调用查找函数
if(p==NULL)
{
printf("没有查到要删除的通讯者!\n");
return;
}
printf("真的要删除改结点吗?(y/n):\n");
scanf("%s",&temp);
if(temp=='y'||temp=='Y')
{
q=head;
while(q!=NULL && q->next!=p)//此循环的含义是将q的指针域赋给p
q=q->next;
q->next=p->next;//删除结点 这里为什么不能用p=p->next
free(p);//释放被删除的节点空间
printf("通讯者已被删除!\n");
}
}
//通讯录链表的输出函数
void PrintList(LinkList head)
{
ListNode *p;
p=head->next;//因为链表带头结点,使p指向链表开始结点

printf(" 姓名 地址 电话 邮 箱 QQ 邮编 \n");
printf("-------------------------------------------------------------------------\n");
/*if((fp=fopen("d://record.txt","r+"))==NULL) //打开文件,并判断打开是否正常
{
printf("打开文件失败!!\n");//没打开
exit(0); //退出
}
while(feof(fp)==0)
{
fscanf(fp,"%15s%20s%15s%30s%10s%10s",p->data.telenub, p->data.name ,p->data.city ,p->data.email,p->data.qq,p->data.youbian);
printf("%15s,%20s,%15s,%30s,%10s,%10s",p->data.telenub, p->data.name ,p->data.city ,p->data.email,p->data.qq,p->data.youbian);
}
fclose(fp);*/
while(p!=NULL)
{
printf("%10s%10s%13s%15s%13s%12s\n",p->data.name,p->data.city,p->data.telenub,p->data.email,p->data.qq,p->data.youbian);
printf("-------------------------------------------------------------------------\n");
p=p->next;//后移一个结点
}
}
void myprint() /* 显示菜单界面 */
{
printf("\n\n");
printf(" |--------------------------------|\n");
printf(" |★☆欢迎进入通讯录管路系统☆★ |\n");
printf(" |--------------------------------|\n");
printf(" | 请输入选项编号(0-5): |\n");
printf(" |--------------------------------|\n");
printf(" | 1--创建通讯录链表 |\n");
printf(" | 2--好友结点的添加 |\n");
printf(" | 3--好友结点的查询 |\n");
printf(" | 4--好友结点的删除 |——————\n");
printf(" | 5--输出通讯录链表 |08信工一班 |\n");
printf(" | 0--退出 | 谭鹏 |\n");
printf(" |--------------------------------|——————\n");
printf("\n\n\n");
}
void main()
{
char choose,yes_no;

do
{
myprint(); /* 显示主菜单 */
printf("\t");
choose=getch();
switch(choose)
{
case '1':printf("********************************************************************\n");
printf("\t\t* 通 讯 录 链 表 的 建 立 *\n ");
printf("\t********************************************************************\n");
head=CreateList(); break; /* 创建 */
case '2':
printf("****************************************************************\n");
printf("\t\t* 通 讯 录 链 表 的 添 加 *\n ");
printf("\t ****************************************************************\n");
printf("\t姓名 地址 电话 邮 箱 QQ 邮编 \n");
printf("\t*******************************************************************\n");
p=(ListNode *)malloc(sizeof(ListNode));//申请新结点
scanf("%s%s%s%s%s%s",p->data.name ,p->data.city ,p->data.telenub ,p->data.email,p->data.qq,p->data.youbian );
if((fp=fopen("tianjia.txt","w+"))==NULL) //打开文件,并判断打开是否正常
{
printf("打开文件失败!!\n");//没打开
exit(0); //退出
}
fprintf(fp,"%-15s%-20s%-15s%-20s%-10s%-12s\n","姓名","城市","电话","邮箱","QQ","邮编" );
InsertNode(head,p);
fprintf(fp,"%-15s%-20s%-15s%-20s%-10s%-12s\n",p->data.name ,p->data.city ,p->data.telenub ,p->data.email,p->data.qq,p->data.youbian );
fclose(fp);

printf("\t\t\t结点添加完毕!");
break; /* 添加 */
case '3':
printf("************************************************************\n");
printf("\t* 好 友 信 息 的 查 询 *\n ");

p=ListFind(head);
if(p!=NULL){
printf(" 姓名 地址 电话 邮 箱 QQ 邮编 \n");
printf("*************************************************************************\n");
printf("%10s%10s%13s%15s%13s%10s\n",p->data.name,p->data.city,p->data.telenub,p->data.email,p->data.qq,p->data.youbian);
printf("*************************************************************************\n");
}
else
printf("没有查到要查询的好友!");
break; /* 查询 */
case '4':
printf("************************************************************\n");
printf("* 好 友 信 息 的 删 除 *\n ");
printf("************************************************************\n");

DelNode(head);//删除结点
break; /* 删除 */
case '5':
printf("************************************************************\n");
printf("\t\t* 显 示 所 有 好 友 信 息 *\n ");
printf("\t ************************************************************\n");
PrintList(head); break; /* 显示 */
case '0': break;
default:printf("\n %c为非法选项!\n",choose);
}
if(choose=='0')
break;
printf("\n 按Y键回主目录:\n\n\n");
do
{
yes_no=getch();
}while(yes_no!='Y'&&yes_no!='y');

}while(yes_no!='Y'||yes_no!='y');

}
温馨提示:答案为网友推荐,仅供参考
第1个回答  2008-12-23
。。。。。100分我都不见的想编这个程序。。。希望楼主能找到有现成程序的人。。。。。。。。祝你好运。。
第2个回答  2008-12-23
这也太麻烦了吧。
人家一看这么多字就懵了
第3个回答  2008-12-23
对于C语言要说已经不错了.
第4个回答  2008-12-23
好多描述哦,我资料里有联系方式
相似回答
大家正在搜