当前位置:首页 » 编程语言 » c语言通讯录管理系统源代码
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言通讯录管理系统源代码

发布时间: 2022-01-18 07:43:04

A. 求一个c语言设计程序:通讯录管理系统

#include<cstdio>
#include<cstdlib>
#include<cstring>
/**通讯录*/
#definename256///名字
#definetele32///手机号
#definebirt32///生日
#definestID32///学号
typedefstructdirectory
{
charName[name];
charTele[tele];
charBirt[birt];
charStID[stID];
structdirectory*next,*prior;
}CONTACTS;
boolJ_T(charp[])///电话号码
{
intlen=strlen(p);
if(len!=11||p[0]!='1')return0;
for(inti=1;i<len;i++)
{
if(!(p[i]>='0'&&p[i]<='9'))
return0;
}
return1;
}
boolJ_L(intyear)///平/润年
{
return(year%4==0&&year%100!=0||year%400==0);
}
boolJ_B(charp[])///生日
{
intlen=strlen(p);
if(!(len>=8&&len<=10))return0;/**1949/1/1(8)1949/12/31(10)**/
intsum=0,Bith[3],k=0;
for(inti=0;i<len;i++)
{
if(!(p[i]>='0'&&p[i]<='9'||p[i]=='/'))///输入合法
return0;
}
p[len]='/';
p[len+1]='';
for(inti=0;i<=len;i++)
{
if(p[i]!='/')
sum=10*sum+p[i]-'0';
else
{
Bith[k++]=sum;
sum=0;
}
}
p[len]='';
if(!(Bith[1]>=1&&Bith[1]<=12))
return0;
switch(Bith[1])
{
case1:case3:case5:case7:case8:case10:case12:
if(!(Bith[2]>=1&&Bith[2]<=31))return0;break;
case4:case6:case9:case11:
if(!(Bith[2]>=1&&Bith[2]<=30))return0;break;
case2:
if(J_L(Bith[0])==1){if(!(Bith[2]>=1&&Bith[2]<=29))return0;}///润年29天
else{if(!(Bith[2]>=1&&Bith[2]<=28))return0;}break;///平年28天
}
return1;
}
boolJ_I(charp[])///学号
{
intlen=strlen(p);
if(len!=11||p[0]==0)return0;
for(inti=1;i<len;i++)
{
if(!(p[i]>='0'&&p[i]<='9'))
return0;
}
return1;
}
voidInput_(CONTACTS*head,boolx)///1,新录入;2,添加
{
printf("录入几个人? ");
intn;
scanf("%d",&n);
getchar();
while(n--)
{
CONTACTS*p,*pnew=newCONTACTS;
if(x==0)
p=head->next;
else
p=head->prior;
printf("名字 ");
gets(pnew->Name);
printf("手机号 ");
while(1)
{
gets(pnew->Tele);
if(J_T(pnew->Tele)==1)
break;
else
printf("输入手机号码错误,请重输 ");
}
printf("生日 ");
while(1)
{
gets(pnew->Birt);
if(J_B(pnew->Birt)==1)
break;
else
printf("输入不正确,请检查 ");
}
printf("学号 ");
while(1)
{
gets(pnew->StID);
if(J_I(pnew->StID)==1)
break;
else
printf("输入学号错误,请检查后重新输入 ");
}
p->next=pnew;
pnew->prior=p;
pnew->next=head;
head->prior=pnew;
}
return;
}
voidOutput_(CONTACTS*head)///输出
{
CONTACTS*p=head->next;
printf("------------------------ ");
while(p!=head)
{
printf("%-8s:%s %-8s:%s %-8s:%s %-8s:%s ","|姓名",p->Name,"|学号",p->StID,"|手机号码",p->Tele,"|生日",p->Birt);
if(p->next!=head)
putchar(' ');
p=p->next;
}
printf("------------------------ ");
return;
}
voidOpen_files(CONTACTS*pHead)///外部倒入数据
{
CONTACTS*pNew,*pNext;
FILE*fp;
charfilename[name];
puts("请输入你要打开文件的地址");
scanf("%s",filename);
if((fp=fopen(filename,"r"))==NULL)
{
puts("无法打开文件");
fflush(stdin);
}
else
{
pNext=(CONTACTS*)malloc(sizeof(CONTACTS));
pHead->next=pNext;
pNext->prior=pHead;
fscanf(fp,"%s%s%s%s",pNext->Name,pNext->StID,pNext->Tele,pNext->Birt);
while(!feof(fp))
{
pNew=(CONTACTS*)malloc(sizeof(CONTACTS));
pNext->next=pNew;
pNew->prior=pNext;
pNext=pNew;
fscanf(fp,"%s%s%s%s",pNext->Name,pNext->StID,pNext->Tele,pNext->Birt);
}
pNext->next=pHead;
pHead->prior=pNext;
puts("导入数据成功!");
fclose(fp);
}
return;
}
voidSave_files(CONTACTS*pHead)///保存数据
{
CONTACTS*p=pHead->next;
FILE*fp;
charfilename[name];
if(p==pHead)
{
puts("无学生信息,请先录入学生信息");
}
else
{
while(1)
{
puts("请输入你要保存文件的地址");
scanf("%s",filename);
if((fp=fopen(filename,"w"))==NULL)
puts("无法打开文件");
else
{
while(p->next!=pHead)
{
fprintf(fp,"%s %s %s %s ",p->Name,p->StID,p->Tele,p->Birt);
p=p->next;
}
fprintf(fp,"%s %s %s %s ",p->Name,p->StID,p->Tele,p->Birt);
puts("保存文件成功!");
fclose(fp);
break;
}
}
}
return;
}
intMenu()
{
system("cls");
printf("-----------------------通讯录----------------------- ");
printf("|******* 1.录入| ");
printf("|******* 2.添加| ");
printf("|******* 3.查看| ");
printf("|******* 4.保存| ");
printf("|******* 5.打开| ");
printf("|******* 0.退出| ");
printf("---------------------------------------------------- ");
inti;
do
{
printf("输入选项:_");
scanf("%d",&i);
}
while(i<0||i>5);
returni;
}
boolLoading(inttime)
{
charadmin[20]={"1"},passw[20]={"1"};
printf(" 用户:______");
charadmi[20],pass[20];
scanf("%s",admi);
if(strcmp(admi,admin)==0)
{
printf(" 密码:______");
scanf("%s",pass);
if(strcmp(pass,passw)==0)
return1;
else
{
printf("密码错误 ");
return0;
}
}
else
{
printf("管理员错误 ");
return0;
}
}
intmain()
{
CONTACTS*head=(CONTACTS*)malloc(sizeof(CONTACTS));
head->next=head->prior=head;
inttimes=5;
printf(" ---------------------------------------------------------------- ");
printf(" |*******通讯录系统*******| ");
printf(" |*******注意:你有%d次机会登陆本系统*******| ",times);
printf(" ---------------------------------------------------------------- ");
while(1)
{
intsign=Loading(times);
if(sign==1||times==1)
break;
times--;
printf("还有%d次机会 ",times);
}
if(times>1)
{
while(1)
{
switch(Menu())
{
case1:Input_(head,0);break;
case2:Input_(head,1);break;
case3:Output_(head);getchar();break;
case4:Save_files(head);getchar();break;
case5:Open_files(head);getchar();break;
case0:exit(0);break;
}
printf("按任意键继续 ");
getchar();
}
}
else
{
printf("退出系统 ");
}
return0;
}


B. 关于C语言程序的个人通讯录管理系统代码

这就是C语言的课程设计,用链表和指针做吧 还要用到结构体

C. C语言,编写一个简单的通讯录管理系统

实现一个通讯录管理系统;

通讯录管理系统可以用来存储1000个人的信息,每个人的信息包括:
姓名、性别、年龄、电话、住址

**提供方法:
1. 添加联系人信息
2. 删除指定联系人信息
3. 查找指定联系人信息
4. 修改指定联系人信息
5. 显示所有联系人信息
6. 清空所有联系人
7. 以名字排序所有联系人**

1、linkman.h(头文件)

3、程序运行结果部分示范:

D. 用C语言编写一个通讯录管理系统。

一个通信录管理程序有以下功能:
. 插入新的通信记录;
. 查找某人的通信记录;
. 删除某人的通信记录;
. 浏览通信录;
. 结束程序运行。
设每条通信录包含以下内容:
.姓名
.地址
.邮政编码
.电话号码
并设通信录全部以字符行形式存于文件中,每四个字符行构成一个通信录记录。
程序启动后,自动从指定的文件中读取通信录信息。程序运行结束后,又自动将内存中修改过的通信录
信息保护到文件中。为了查找,插入,删除等操作的方便,程序内部以双向链表形式组织通信录信息。设启
动程序的命令行可带通信录文件参数。如启动时未给出文件名参数,则程序首先要求用户键入通信录文件
名。程序运行时,反复显示请求输入操作命令的提示信息:
请输入命令: [i, f, d, s, q]
即要求用户打入一条命令,它可以是 i(插入)、f(寻找)、d(删除)、s(显示)以及q(结束程序运行)。如果打
入命令不是其中之一, 将详细显示命令符及其意义的说明:
命令表:
i : 插入一条新的通信记录.
f : 按输入名查找通信录.
d : 按输入名删除一条通信录.
s : 浏览通信录.
q : 退出.
然后重新请求打入操作命令的提示信息。程序将全部通信录组织成一个双向勾链的链表。接受显示通信录表
的命令后,首先显示的是第一条通信录,由用户键入Up键或Down键分别实现向上或向下选择,显示下一条通信录。键入Escape键结束显示命令。上述三键在显示一条通信录之后,在下面给出提示。按其他键不予理睬.

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAXL 120

typedef struct saddr {
char *name;
char *address;
char *zip;
char *phone;
struct saddr *next, *pre;
} ADDR;

char buffer[MAXL], fname[40];
FILE *fp;
int modified = 0;

ADDR *load();
void insert(), make(), find(), del(), display(), show(),
save(), freeall(), usage();
int getstr(FILE*, char **), getbuffer(FILE *);

int main(int argc, char **argv)
{
ADDR *head;
char c;
if (argc == 1) {
printf("请输入通信录文件名. ");
scanf("%s%*c", fname);
}
else{
strcpy(fname, *++argv);
}
head = load(fname);
while (1) {
printf("\n请输入命令: [i, f, d, s, q]\n");
while (getbuffer(stdin) == 0);
if ((c = buffer[0]) == 'q') {
if (modified) {
printf("修改后的通信录未保存,要保存吗?(y/n) ");
while (!(((c = getchar()) >= 'a' && c <= 'z') �0�7�0�7 (c >= 'A' && c <= 'Z')))continue;
if (c == 'y' �0�7�0�7 c == 'Y')
save(head, fname);
}
freeall(head);
break;
}

E. 用C语言. 编写一个“通讯录管理系统”程序

#include
#include
#include
struct worker
{
char name[30]; //name职工姓名
char ID[10]; //ID职工编号
char sex[3];
int birth;
int tel;
char ec[10];
char addr[30];
char cheng[10];
int year;
};
int dq(struct worker wo[]);
void show();
void bc(struct worker wo[]);
void add();
void see();
void search();
void ghcz();
void xmcz();
void del();
void ghxg();
void reserve();
//void back();
struct worker wo[100]; //保存所有的职工信息
int Number=0; //记录总的职工人数
int main()
{
int choose=0;
system("color 1e");//更改背景颜色
while(1)
{
show();
printf("\t\t====>请选择:");
scanf("%d",&choose);
system("cls");//清屏
switch(choose)
{
case 0: exit(0);//退出
break;
case 1: add();
back();//添加职工信息
break;
case 2: see();
back();//查看职工信息
break;
case 3: search();
back();
break;
case 4: del();
back();
break;
case 5:ghxg();
back();
break;
case 6:reserve();
back();
break;

default:
back();

break;
}
fflush(stdin);//?清空输入缓冲区,通常是为了确保不影响后面的数据读取
getchar();
system("cls");//清屏
}
}

int dq(struct worker wo[])//怎么初始化?打开文件出现乱码。这个不肯定,可能是二进制文件,而你是用文本文档的方式打开的
{
FILE *fp=NULL;
int i=0;
fp=fopen("C://worker.dat","rb");
while(fread(&wo[i],sizeof(struct worker),1,fp))//?从woker.dat文件读取数据到结构体数组wo[], 一次读取一个工人的全部数据
i++;
fclose(fp);
return i;
}

void show() //程序主界面函数
{
printf("\n");
printf("\t****************职工工资管理系统****************\n\n");

printf("\t***************[1] 添加职工信息*****************\n");

printf("\t***************[2] 查看职工信息*****************\n");

printf("\t***************[3] 查找职工信息*****************\n");

printf("\t***************{4] 删除职工信息*****************\n");<br/> <br/> printf("\t***************[5] 修改职工信息*****************\n");<br/> <br/> printf("\t***************[6] 保 存 数 据*****************\n");<br/> <br/> printf("\t***************[7] 作 者 信 息*****************\n");<br/> <br/> printf("\t***************[0] 退 出 系 统*****************\n\n");<br/>}

void bc(struct worker *wo)
{
FILE *fp=NULL;
fp=fopen("C://worker.dat","ab+");
fwrite(wo,sizeof(struct worker),1,fp);
fclose(fp);
}
//添加职工信息
void add()
{
int numberTemp=0;
int i=0;
struct worker temp;
printf("请输入要添加职工个数:");
scanf("%d",&numberTemp);
for(i=0;i修改成功\n");
}
//保存数据

F. 求一个C语言通讯录管理系统的代码,要正确的!

#include <stdio.h>
#include <stdlib.h> /*与malloc.h差不多*/
#include <string.h>
#include <iostream>
using namespace std;
#define maxlen 15
struct persons
{int num; /*定义结构体数组用于缓存数据*/
char name[20];
char e_addr[20];
char tel_no[15];
char sim_no;
char arch;
}persons[maxlen];

typedef struct lnode
{ /*通讯录结构中结点的定义*/
int num;
char name[20];
char e_addr[20];
char tel_no[15];
char sim_no;
char arch;
struct lnode *next;
}listnode,*linklist;

linklist head=NULL,r=NULL; /*定义头指针和尾指针*/
listnode *s,*p0,*p1,*p2,*p3,*p4,*p5,*p6,*p7,*p8,*p9;
int i;
char name1[10],ch;
char tel_no1[15];
char arch1;
char sim_no1;
char e_addr1[20];
char s1[20];
FILE *fp; /*定义文件指针*/

void creat() /*将文件的信息读入结构体数组在转存入链表中*/
{ int j;
long k;
fp=fopen("数据文件.txt","r t"); /*打开文件*/
if(fp!=NULL)
{for(i=0;i<=maxlen;i++ )
{ j=fgetc(fp);
if(j==EOF)
return;
k=i;
fseek(fp,k*sizeof(struct persons),0); /*读取一个人的信息*/
fread(&persons[i],sizeof(struct persons),1,fp);

s=(linklist)malloc(sizeof(listnode)); /*装存入链表中*/
s->num=persons[i].num;
strcpy(s->name,persons[i].name);
strcpy(s->e_addr,persons[i].e_addr);
strcpy(s->tel_no,persons[i].tel_no);
s->sim_no=persons[i].sim_no;
s->arch=persons[i].arch;
if(head==NULL) /*用尾插法将其插入链表中*/
{head=s;r=head;head->next=NULL;}
else
{r->next=s;
r=s;r->next=NULL;
}
}fclose(fp);
}
else
{ fp=fopen("数据文件.txt","w"); /*不能打开另开辟一个文件*/
i=1;
}
}

void Show()
{printf("成功调用该函数\n");}
void Delete()
{printf("成功调用该函数\n");}

void Input() /*向.通讯录中输入一个人的信息*/
{ s=(linklist)malloc(sizeof(listnode));
printf("\n\n\t请输入该用户的信息:");
printf("姓名:");
scanf("%s",&s->name);
printf("电话号码:");
scanf("%s",&s->tel_no);
printf("单键拨号:");
scanf("%s",&s->sim_no);
printf("E-mail地址:");
scanf("%s",&s->e_addr);
printf("类别:");
scanf("%s",&s->arch);

if(head==NULL)printf("\n\n");
else
{p8=head;
while(p8!=NULL&&strcmp(s->name,p8->name)!=0&&strcmp(s->tel_no,p8->tel_no)!=0)
p8=p8->next;
if(p8!=NULL)
{printf("您添加的用户已存在!");
free(s);}}
if(head==NULL)
{
s->next = 0;
head=s;
r = s;
}
else
{
s->next = 0;
r->next = s;
r = s;

}
}
void Alter()
{ printf("success!\n");}
int main()
{
system("color a");
creat();
do
{
printf("\n\n\t\t请选择操作:");
printf("\n\t\t1.显示通讯录");
printf("\n\t\t2.删除通讯录");
printf("\n\t\t3.添加通讯录");
printf("\n\t\t4.编辑通讯录");
printf("\n\n\n");
printf("\t请选择:");
cin>>ch;
switch(ch)
{ case '1': Show(); /*用单条件多选择语句实现调用与循环*/
break;
case '2': Delete();
break;
case '3': Input();
break;
case '4': Alter();
break;
fclose(fp);
exit(0);
break;
default:
printf("\n\t The num should 1-6!!! \n");
break;
}
}
while(1);
}

G. 急求通讯录管理系统(有链表的)数据结构c语言版的源代码。要求c++可以测试通过

这个绝对满足了你的要求了,谢谢采纳`

#include<iostream.h>
#include<string>
#include<stdlib.h>
class List;
class person
{
public:
friend class List;
private:
person() {next=0;}
person *next;
char name[10],tel[15];
};

class List
{
public:

List(){list=0;}
int gncd(); // 功能菜单
int print(); // 输出所有信息
int append(); // 增加一个信息
int revise(); // 根据姓名、电话修改信息
int dele(); // 根据姓名、电话删除信息
int exit(); // 退出
private:
person *end();
person *list;

};
int List::exit()
{
abort();
return 1;
}

int List::gncd()
{
cout<<"************欢迎使用****************************"<<endl;
cout<<"1.输入信息。"<<endl;
cout<<"2.根据姓名、电话修改信息。"<<endl;
cout<<"3.根据姓名、电话删除信息"<<endl;
cout<<"4.输出所有现有成员信息"<<endl;
cout<<"5.退出"<<endl;
cout<<"选择:";
int a;
cin>>a;
switch(a)
{
case(1):this->append();break;
case(2):this->revise();break;
case(3):this->dele();break;
case(4):this->print();break;
case(5):this->exit();break;
}
this->gncd();
return 1;
}

int List::print()
{
if(list==0)
{
cout<<"为空或没输入内容"<<endl;
return 0;
}

person *p=list;
while(p!=NULL)
{
cout<<"姓名:"<<p->name<<endl;
cout<<"电话:"<<p->tel<<endl;
p=p->next;
}
cout<<endl;
return 1;
}

int List::append()
{
person *p=new person;

cout<<"请输入姓名:"<<endl;
cin>>p->name;
cout<<"请输入电话号码:"<<endl;
cin>>p->tel;

char temp;
cout<<"是否继续输入(y/n)";
cin>>temp;
if(temp=='y'||temp=='Y')
this->append();

if(list==0)
list=p;
else
(end())->next=p;
return 1;
}
person *List::end()
{
person *p,*q;
for(q=p=list;p;q=p,p=p->next) ;
return q;
}

int List::revise()
{
person *p=list;
char temp[20];
cout<<"你选择了根据姓名、电话修改信息。"<<endl<<"请输入将要修改的姓名或电话:";
cin>>temp;
int i=0;
while(p!=NULL)
{
if(!strcmp(p->name,temp)||!strcmp(p->tel,temp))
{
i=1;
cout<<"请输入新的姓名:";
cin>>p->name;
cout<<"请输入新的电话号码:";
cin>>p->tel;

}
p=p->next;
}
if(i==1) cout<<"修改成功!"<<endl;
if(i!=1) cout<<"未能找到。"<<endl;
return 1;
}

int List::dele()
{
person *q,*p=list;
char temp[20];
cout<<"你选择了根据姓名、电话删除信息。"<<endl<<"请输入将要删除的姓名或电话:";
cin>>temp;
if(p==NULL)
cout<<"为空或没有输入信息。"<<endl;
if(!strcmp(p->name,temp)||!strcmp(p->tel,temp)) //要删除的结点是第一个时
{
list=p->next;
delete p;
cout<<"删除成功!"<<endl;
}
else
{
while(p!=NULL&&(strcmp(p->name,temp)||strcmp(p->tel,temp)))
{
q=p;
p=p->next;
}
if(p==NULL) return 0;

else if(q==NULL)
cout<<"没能找到。"<<endl;
else
{
q->next=p->next;
delete p;
cout<<"删除成功!"<<endl;
}

}

return 1;
}

void main()
{
List L;
L.gncd();

}

H. 学生通讯录管理系统C语言编写程序

才0分啊,需要,我给你

I. 求用C语言编写一个学生通讯录管理系统

运行成功~#include
"stdio.h"
#include
"stdlib.h"
#include
"string.h"
int
shoudsave=0;
/*
*/
struct
student
{
char
num[10];/*
学号
*/
char
name[20];
char
sex[4];
int
cgrade;
int
mgrade;
int
egrade;
int
totle;
int
ave;
char
neartime[10];/*
最近更新时间
*/
};
typedef
struct
node
{
struct
student
data;
struct
node
*next;
}Node,*Link;
void
menu()
{
printf("********************************************************************************");
printf("\t1登记学生资料\t\t\t\t\t2删除学生资料\n");
printf("\t3查询学生资料\t\t\t\t\t4修改学生资料\n");
printf("\t5保存学生资料\t\t\t\t\t6作者介绍\n");
printf("\t0退出系统\n");
printf("********************************************************************************\n");
}
void
printstart()
{
printf("-----------------------------------------------------------------------\n");
}
void
Wrong()
{
printf("\n=====>提示:输入错误!\n");
}
void
Nofind()
{
printf("\n=====>提示:没有找到该学生!\n");
}
void
printc()
/*
本函数用于输出中文
*/
{
printf("
学号\t
姓名
性别
英语成绩
数学成绩
C语言成绩
总分
平均分\n");
}
void
printe(Node
*p)/*
本函数用于输出英文
*/
{
printf("%-12s%s\t%s\t%d\t%d\t%d\t
%d\t
%d\n",p->data.num,p->data.name,p->data.sex,p->data.egrade,p->data.mgrade,p->data.cgrade,p->data.totle,p->data.ave);
}
Node*
Locate(Link
l,char
findmess[],char
nameornum[])
/*
该函数用于定位连表中符合要求的接点,并返回该指针
*/
{
Node
*r;
if(strcmp(nameornum,"num")==0)
/*
按学号查询
*/
{
r=l->next;
while(r!=NULL)
{
if(strcmp(r->data.num,findmess)==0)
return
r;
r=r->next;
}
}
else
if(strcmp(nameornum,"name")==0)
/*
按姓名查询
*/
{
r=l->next;
while(r!=NULL)
{
if(strcmp(r->data.name,findmess)==0)
return
r;
r=r->next;
}
}
return
0;
}
void
Add(Link
l)
/*
增加学生
*/
{
Node
*p,*r,*s;
char
num[10];
r=l;
s=l->next;
while(r->next!=NULL)
r=r->next;
/*
将指针置于最末尾
*/
while(1)
{
printf("请你输入学号(以'0'返回上一级菜单:)");
scanf("%s",num);
if(strcmp(num,"0")==0)
break;
while(s)
{
if(strcmp(s->data.num,num)==0)
{
printf("=====>提示:学号为'%s'的学生已经存在,若要修改请你选择'4
修改'!\n",num);
printstart();
printc();
printe(s);
printstart();
printf("\n");
return;
}
s=s->next;
}
p=(Node
*)malloc(sizeof(Node));
strcpy(p->data.num,num);
printf("请你输入姓名:");
scanf("%s",p->data.name);
getchar();
printf("请你输入性别:");
scanf("%s",p->data.sex);
getchar();
printf("请你输入c语言成绩:");
scanf("%d",&p->data.cgrade);
getchar();
printf("请你输入数学成绩:");
scanf("%d",&p->data.mgrade);
getchar();
printf("请你输入英语成绩:");
scanf("%d",&p->data.egrade);
getchar();
p->data.totle=p->data.egrade+p->data.cgrade+p->data.mgrade;
p->data.ave=p->data.totle
/
3;
/*
信息输入已经完成
*/
p->next=NULL;
r->next=p;
r=p;
shoudsave=1;
}
}
void
Qur(Link
l)
/*
查询学生
*/
{
int
sel;
char
findmess[20];
Node
*p;
if(!l->next)
{
printf("\n=====>提示:没有资料可以查询!\n");
return;
}
printf("\n=====>1按学号查找\n=====>2按姓名查找\n");
scanf("%d",&sel);
if(sel==1)/*
学号
*/
{
printf("请你输入要查找的学号:");
scanf("%s",findmess);
p=Locate(l,findmess,"num");
if(p)
{
printf("\t\t\t\t查找结果\n");
printstart();
printc();
printe(p);
printstart();
}
else
Nofind();
}
else
if(sel==2)
/*
姓名
*/
{
printf("请你输入要查找的姓名:");
scanf("%s",findmess);
p=Locate(l,findmess,"name");
if(p)
{
printf("\t\t\t\t查找结果\n");
printstart();
printc();
printe(p);
printstart();
}
else
Nofind();
}
else
Wrong();
}
void
Del(Link
l)
/*
删除
*/
{
int
sel;
Node
*p,*r;
char
findmess[20];
if(!l->next)
{
printf("\n=====>提示:没有资料可以删除!\n");
return;
}
printf("\n=====>1按学号删除\n=====>2按姓名删除\n");
scanf("%d",&sel);
if(sel==1)
{
printf("请你输入要删除的学号:");
scanf("%s",findmess);
p=Locate(l,findmess,"num");
if(p)
{
r=l;
while(r->next!=p)
r=r->next;
r->next=p->next;
free(p);
printf("\n=====>提示:该学生已经成功删除!\n");
shoudsave=1;
}
else
Nofind();
}
else
if(sel==2)
{
printf("请你输入要删除的姓名:");
scanf("%s",findmess);
p=Locate(l,findmess,"name");
if(p)
{
r=l;
while(r->next!=p)
r=r->next;
r->next=p->next;
free(p);
printf("\n=====>提示:该学生已经成功删除!\n");
shoudsave=1;
}
else
Nofind();
}
else
Wrong();
}
void
Modify(Link
l)
{
Node
*p;
char
findmess[20];
if(!l->next)
{
printf("\n=====>提示:没有资料可以修改!\n");
return;
}
printf("请你输入要修改的学生学号:");
scanf("%s",findmess);
p=Locate(l,findmess,"num");
if(p)
{
printf("请你输入新学号(原来是%s):",p->data.num);
scanf("%s",p->data.num);
printf("请你输入新姓名(原来是%s):",p->data.name);
scanf("%s",p->data.name);
getchar();
printf("请你输入新性别(原来是%s):",p->data.sex);
scanf("%s",p->data.sex);
printf("请你输入新的c语言成绩(原来是%d分):",p->data.cgrade);
scanf("%d",&p->data.cgrade);
getchar();
printf("请你输入新的数学成绩(原来是%d分):",p->data.mgrade);
scanf("%d",&p->data.mgrade);
getchar();
printf("请你输入新的英语成绩(原来是%d分):",p->data.egrade);
scanf("%d",&p->data.egrade);
p->data.totle=p->data.egrade+p->data.cgrade+p->data.mgrade;
p->data.ave=p->data.totle/3;
printf("\n=====>提示:资料修改成功!\n");
shoudsave=1;
}
else
Nofind();
}
void
Disp(Link
l)
{
int
count=0;
Node
*p;
p=l->next;
if(!p)
{
printf("\n=====>提示:没有资料可以显示!\n");
return;
}
printf("\t\t\t\t显示结果\n");
printstart();
printc();
printf("\n");
while(p)
{
printe(p);
p=p->next;
}
printstart();
printf("\n");
}
void
Tongji(Link
l)
{
Node
*pm,*pe,*pc,*pt,*pa;
/*
用于指向分数最高的接点
*/
Node
*r=l->next;
if(!r)
{
printf("\n=====>提示:没有资料可以统计!\n");
return
;
}
pm=pe=pc=pt=pa=r;
while(r!=NULL)
{
if(r->data.cgrade>=pc->data.cgrade)
pc=r;
if(r->data.mgrade>=pm->data.mgrade)
pm=r;
if(r->data.egrade>=pe->data.egrade)
pe=r;
if(r->data.totle>=pt->data.totle)
pt=r;
if(r->data.ave>=pa->data.ave)
pa=r;
r=r->next;
}
printf("------------------------------统计结果--------------------------------\n");
printf("总分最高者:\t%s
%d分\n",pt->data.name,pt->data.totle);
printf("平均分最高者:\t%s
%d分\n",pa->data.name,pa->data.ave);
printf("英语最高者:\t%s
%d分\n",pe->data.name,pe->data.egrade);
printf("数学最高者:\t%s
%d分\n",pm->data.name,pm->data.mgrade);
printf("c语言最高者:\t%s
%d分\n",pc->data.name,pc->data.cgrade);
printstart();
}
void
Writer()
{
printf("
我就是传说中的SDDF.啊哈哈\n\n");
}
void
Sort(Link
l)
{
Link
ll;
Node
*p,*rr,*s;
ll=(Link)malloc(sizeof(Node));
/*
用于做新的连表
*/
ll->next=NULL;
if(l->next==NULL)
{
printf("\n=====>提示:没有资料可以排序!\n");
return
;
}
p=l->next;
while(p)
{
s=(Node*)malloc(sizeof(Node));
/*
新建接点用于保存信息
*/
s->data=p->data;
s->next=NULL;
rr=ll;
while(rr->next!=NULL
&&
rr->next->data.totle>=p->data.totle)
rr=rr->next;
if(rr->next==NULL)
rr->next=s;
else
{
s->next=rr->next;
rr->next=s;
}
p=p->next;
}
free(l);
l->next=ll->next;
printf("\n=====>提示:排序已经完成!\n");
}
void
Save(Link
l)
{
FILE*
fp;
Node
*p;
int
flag=1,count=0;
fp=fopen("c:\\student","wb");
if(fp==NULL)
{
printf("\n=====>提示:重新打开文件时发生错误!\n");
exit(1);
}
p=l->next;
while(p)
{
if(fwrite(p,sizeof(Node),1,fp)==1)
{
p=p->next;
count++;
}
else
{
flag=0;
break;
}
}
if(flag)
{
printf("\n=====>提示:文件保存成功.(有%d条记录已经保存.)\n",count);
shoudsave=0;
}
fclose(fp);
}
void
main()
{
Link
l;/*
连表
*/
FILE
*fp;
/*
文件指针
*/
int
sel;
char
ch;
char
jian;
int
count=0;
Node
*p,*r;
printf("\t\t\t\t学生成绩管理系统\n\t\t\t\t\n");
l=(Node*)malloc(sizeof(Node));
l->next=NULL;
r=l;
fp=fopen("C:\\student","rb");
if(fp==NULL)
{
printf("\n=====>提示:文件还不存在,是否创建?(y/n)\n");
scanf("%c",&jian);
if(jian=='y'||jian=='Y')
fp=fopen("C:\\student","wb");
else
exit(0);
}
printf("\n=====>提示:文件已经打开,正在导入记录......\n");
while(!feof(fp))
{
p=(Node*)malloc(sizeof(Node));
if(fread(p,sizeof(Node),1,fp))
/*
将文件的内容放入接点中
*/
{
p->next=NULL;
r->next=p;
r=p;
/*
将该接点挂入连中
*/
count++;
}
}
fclose(fp);
/*
关闭文件
*/
printf("\n=====>提示:记录导入完毕,共导入%d条记录.\n",count);
while(1)
{
menu();
printf("请你选择操作:");
scanf("%d",&sel);
if(sel==0)
{
if(shoudsave==1)
{
getchar();
printf("\n=====>提示:资料已经改动,是否将改动保存到文件中(y/n)?\n");
scanf("%c",&ch);
if(ch=='y'||ch=='Y')
Save(l);
}
printf("\n=====>提示:你已经退出系统,再见!\n");
break;
}
switch(sel)
{
case
1:Add(l);break;
/*
增加学生
*/
case
2:Del(l);break;/*
删除学生
*/
case
3:Qur(l);break;/*
查询学生
*/
case
4:Modify(l);break;/*
修改学生
*/
case
5:Save(l);break;/*
保存学生
*/
case
6:Writer();break;/*作者介绍*/
case
9:printf("\t\t\t==========帮助信息==========\n");break;
default:
Wrong();getchar();break;
}
}
}
/*
*/

J. c语言通讯录管理系统

#include<stdio.h>
#include<stdlib.h>

#define MAX 100

struct addr{
char name[30];
char street[40];
char city[20];
char state[3];
unsigned long int zip;
}addr_list[MAX];

void init_list(void);
int menu_select(void);
void enter(void);
int find_free(void);
void deleted(void);
void list(void);

int main(void){
char choice;

init_list(); /* initialize the structure array */

for(;;){
choice=menu_select();
switch(choice){
case 1:
enter();
break;
case 2:
deleted();
break;
case 3:
list();
break;
case 4:
exit(0);
}
}

return 0;
}

/* initialize the list*/
void init_list(void){
register int t;

for(t=0;t<MAX;++t)
addr_list[t].name[0]='\0';
}

/* Get a menu selection*/
int menu_select(void){
int c;

printf("1.Enter a name\n");
printf("2.deleted a name\n");
printf("3.List the file\n");
printf("4.Quit\n");

do{
printf("\nEnter your choice:");
scanf("%d",&c);
}while(c<0||c>4);

return c;
}

/* Input address into the list*/
void enter(void){
int slot;
char s[80];

slot=find_free();
if(slot==-1){
printf("\nList Full");
return;
}

printf("Enter name: ");
gets(addr_list[slot].name);
printf("Enter street: ");
gets(addr_list[slot].street);
printf("Enter city: ");
gets(addr_list[slot].city);
printf("Enter state: ");
gets(addr_list[slot].state);
printf("Enter zip: ");
gets(s);
addr_list[slot].zip=strtoul(s,'\0',10);
}

/* Find an unused structure.*/
int find_free(void){
register int t;

for(t=0;addr_list[t].name[0]&&t<MAX;++t);

if(t==MAX)
return -1;
return t;
}

/* deleted an address.*/
void deleted(void){
register int slot;
char s[80];

printf("Enter record #: ");
gets(s);
slot=atoi(s);
if(slot>=0&&slot<MAX)
addr_list[slot].name[0]='\0';
}

/* Display the list on the screen*/
void list(void){
register int t;

for(t=0;t<MAX;++t){
if(addr_list[t].name[0]){
printf("%s\n",addr_list[t].name);
printf("%s\n",addr_list[t].street);
printf("%s\n",addr_list[t].city);
printf("%s\n",addr_list[t].state);
printf("%lu\n",addr_list[t].zip);
}
}
printf("\n\n");
}

我以前写的