您现在的位置:计算机技术学习网 > 技术中心 > 编程开发 > C >

c语言课程设计_简单通讯录系统

来源:不详 责任编辑:栏目编辑 发表时间:2013-07-02 01:25 点击:

/*简单通讯录*/
#include <stdio.h>
#include <stdlib.h>
struct address{
  char name[20];
  char street[20];
  char city[10];
  char state[10];
  char zip[7];
  struct address *next;
  struct address *prior;
  }list_entry;

struct address *start;
struct address *last;

void enter();
void display();
void search();
void save();
void load();
void list();

struct address *find(char *name);
struct address *dls_store(struct address *,struct address *);

main()
{
clrscr();
start=last=NULL;
load();
for (;;){
  switch(menu_select()){
    case 1:enter();break;
    case 2:delete();break;
    case 3:list();break;
    case 4:search();break;
    case 5:save();break;
    case 6:exit(0);
    }
  }
}

menu_select()
{
char c;
printf("1.Enter\n");
printf("2.Delete\n");
printf("3.List\n");
printf("4.Search\n");
printf("5.Save\n");
printf("6.Quit\n");
do{
  printf("\nEnter you choice:");
  c=getche();
  }while (c<'0'||c>'6');
return c-48;
}

void enter()
{
struct address *info;
for (;;){
  info=(struct address *)malloc(sizeof(list_entry));
  if (!info){
    printf("\nout of memory");
  return;
  }
  inputs("\nenter name:",info->name,19);
  if (!info->name[0]) break;
  inputs("enter street:",info->street,19);
  inputs("enter city:",info->city,9);
  inputs("enter state:",info->state,9);
  inputs("enter zip:",info->zip,6);
  start=dls_store(info,start);
  }
}

inputs(char *prompt,char *s,int count)
{
char p[255];
do{
  printf(prompt);
  gets(p);
  if (strlen(p)>count) printf("\ntoo long\n");
  }while (strlen(p)>count);
  strcpy(s,p);
}

struct address *dls_store(struct address *i,struct address *top)
{
struct address *old,*p;
if (last==NULL){
  i->next=NULL;
  i->prior=NULL;
  last=i;
  return i;
  }
p=top;
old=NULL;
while(p){
  if (strcmp(p->name,i->name)<0){
    old=p;p=p->next;
    }
  else{
    if(p->prior){
      p->prior->next=i;
      i->next=p;
      i->prior=p->prior;
      p->prior=i;
      return top;
      }
    i->next=p;
    i->prior=NULL;
    p->prior=i;
    return i;
    }
  }
  old->next=i;
  i->next=NULL;
  i->prior=old;
  last=i;
  return start;
}

delete()
{
struct address *info;
char s[80];
printf("enter name:");
gets(s);
info=find(s);
if (info) {
  if (start==info){
    start=info->next;
    if (start)
      start->prior=NULL;
    else
      last=NULL;
    }
  else{
    info->prior->next=info->next

    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • Glib实例学习(2)双链表
    • C程序员要学C++吗?
    • C++中实现Singleton的正确方法
    • 编程思维训练(一)
    • 【编程好习惯】引入中间变量使程序更易读
    • 在C++中通过模板规避潜在错误
    • 在C++中通过模板去除强制转换
    • 【编程好习惯】减少搜索头文件的目录数
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1