C语言程序设计:通讯录程序设计

作者&投稿:出影 (若有异议请与网页底部的电邮联系)
求c语言通讯录程序设计~

给,已经编译运行确认了:
#include
#include
#include
#include
struct record
{
char id[10];
char name[20];
char phone[20];
char adress[40];
char postcode[10];
char e_mail[30];
}student[500];
int num=0;//外部变量num为文件中的纪录数
FILE *fp;
void mainmenu();//主菜单
void newrecord();//新添纪录
void searchmenu();//查询菜单
void searchbyid();//按学号查询
void searchbyname();//按姓名查询
void searchbyphone();//按电话查询
void deletemenu();//删除菜单
void deleteall();//删除所有
void deleteone();//删除单个
void showall();//显示所有
void readfromfile();//读取文件
void writetofile();//写入文件
void deletebyid();//按学号删除
void deletebyname();//按姓名删除
void listbyid();//按学号排序
void listbyname();//按姓名排序
void listmenu();//排序菜单
void main()
{
readfromfile();
while (1)
{
mainmenu();
}
}
void readfromfile()//从文件导入
{
if((fp=fopen("student.bin","rb"))==NULL)
{
printf("
通讯录文件不存在");
if ((fp=fopen("student.bin","wb"))==NULL)
{
printf("
建立失败");
exit(0);
}
else
{
printf("
通讯录文件已建立");
printf("
按任意键进入主菜单");
getch();
return;
}
exit(0);
}
fseek(fp,0,2); /*文件位置指针移动到文件末尾*/
if (ftell(fp)>0) /*文件不为空*/
{
rewind(fp); /*文件位置指针移动到文件开始位置*/
for (num=0;!feof(fp) && fread(&student[num],sizeof(struct record),1,fp);num++);
printf("
文件导入成功");
printf("
按任意键返回主菜单");
getch();
return;
}
printf("
文件导入成功");
printf("
通讯录文件中无任何纪录");
printf("
按任意键返回主菜单");
getch();
return;
}
void mainmenu()//主菜单
{
char choic;
system("cls");
printf("
******************** 主菜单 ********************");
printf("
*********** 1-新添纪录 2-查询菜单 ************");
printf("
*********** 3-删除菜单 4-记录排序 ************");
printf("
*********** 5-保存退出 6-不保存退出***********");
printf("
************************************************");
printf("
请选择:");
choic=getch();
switch (choic)
{
case '1':newrecord();break;
case '2':searchmenu();break;
case '3':deletemenu();break;
case '4':listmenu();break;
case '5':writetofile();break;
case '6':exit(0);
default:mainmenu();
}
}
void searchmenu()//查询菜单
{
char choic;
system("cls");
printf("
******************* 查询菜单 *******************");
printf("
********** 1-显示所有 2-按学号查询 ************");
printf("
********** 3-按姓名查询4-按电话查询 ************");
printf("
********** 5-返回主菜单 ************");
printf("
************************************************");
printf("
请选择:");
choic=getch();
switch (choic)
{
case '1':showall();break;
case '2':searchbyid();break;
case '3':searchbyname();break;
case '4':searchbyphone();break;
case '5':mainmenu();break;
}
}
void deletemenu()//删除菜单
{
char choic;
if(num==0)
{
printf("
对不起,文件中无任何纪录");
printf("
按任意键返回主菜单");
getch();
return;
}
system("cls");
printf("
******************* 删除菜单 *******************");
printf("
*********** 1-删除所有 2-删除单个 ***********");
printf("
*********** 3-返回主菜单 ***********");
printf("
************************************************");
printf("
请选择:");
choic=getch();
switch (choic)
{
case '1':deleteall();break;
case '2':deleteone();break;
case '3':mainmenu();break;
default:mainmenu();break;
}
}
void deleteall()//删除所有
{
printf("
确认删除?(y/n)");
if (getch()=='y')
{
fclose(fp);
if ((fp=fopen("student.bin","wb"))==NULL)
{
printf("
不能打开文件,删除失败");
readfromfile();
}
num=0;
printf("
纪录已删除,按任意键返回主菜单");
getch();
return;
}
else
return;
}
void deletebyname()//按姓名删除
{
int a=0;
int findmark=0;
int j;
int deletemark=0;
int i;
char name[20];
printf("
请输入要删除学生姓名:");
scanf("%s",name);
for (i=a;i<num;i++)
{
if (strcmp(student[i].name,name)==NULL)
{
printf("
以下是您要删除的学生纪录:");
findmark++;
printf("
________________________________");
printf("
学号: %s",student[i].id);
printf("
姓名: %s",student[i].name);
printf("
电话: %s",student[i].phone);
printf("
地址: %s",student[i].adress);
printf("
e-mail:%s",student[i].e_mail);
printf("
________________________________");
printf("
是否删除?(y/n)");
if (getch()=='y')
{
for (j=i;j<num-1;j++) /*纪录移动,从stud数组中删除之*/
student[j]=student[j+1];
num--;
deletemark++;
printf("
删除成功");
if((i+1)<num)
{
printf("
是否继续删除相同姓名的同学信息?(y/n)");
if (getch()=='y')
{
a=i;
continue;
}
}
printf("
是否继续删除?(y/n)");
if (getch()=='y')
deletebyname();
return;
}
if((i+1)<num)
{
printf("
是否继续删除相同姓名的同学信息?(y/n)");
if (getch()=='y')
{
a=i;
continue;
}
}
}
else
continue;
}
if ((deletemark==0)&&(findmark==0))
{
printf("
没有该同学的纪录");
printf("
是否继续删除?(y/n)");
if (getch()=='y')
deletebyid();
return;
return;
}
else if (findmark!=0)
{
printf("
没有重名信息");
printf("
没有该同学的纪录");
printf("
是否继续删除?(y/n)");
if (getch()=='y')
deletebyid();
return;
return;
}
}
void deletebyid()//按学号删除
{
int i,j;
int deletemark=0;
char id[20];
printf("
请输入要删除学生学号:");
scanf("%s",id);
if(num==0)
{
printf("
对不起,文件中无任何纪录");
printf("
按任意键返回主菜单");
getch();
return;
}
for (i=0;i<num;i++)
{
if (strcmp(student[i].id,id)==NULL)
{
printf("
以下是您要删除的学生纪录:");
printf("
学号: %s",student[i].id);
printf("
姓名: %s",student[i].name);
printf("
电话: %s",student[i].phone);
printf("
地址: %s",student[i].adress);
printf("
e-mail:%s",student[i].e_mail);
printf("
是否删除?(y/n)");
if (getch()=='y')
{
for (j=i;j<num-1;j++) /*纪录移动,从stud数组中删除之*/
student[j]=student[j+1];
num--;
deletemark++;
printf("
删除成功");
printf("
是否继续删除?(y/n)");
if (getch()=='y')
deletebyid();
return;
}
else
return;
}
continue;

}
if (deletemark==0)
{
printf("
没有该同学的纪录");
printf("
是否继续删除?(y/n)");
if (getch()=='y')
deletebyid();
return;
}
}
void newrecord()//添加纪录
{
printf("
**************** 请输入学生信息 ****************
");
printf("
输入学号:");
scanf("%s",&student[num].id);
printf("
输入姓名:");
scanf("%s",&student[num].name);
printf("
输入电话号码:");

scanf("%s",&student[num].phone);
printf("
输入地址:");
scanf("%s",&student[num].adress);
printf("
输入邮编:");
scanf("%s",&student[num].postcode);
printf("
输入e-mail:");
scanf("%s",&student[num].e_mail);
num++;
printf("
是否继续添加?(Y/N):");
if (getch()=='y')
newrecord();
return;
}
void showall()//显示所有
{
int i;
system("cls");
if(num!=0)
{
printf("
*************** 以下为通讯录所有信息************");
for (i=0;i<num;i++)
{
printf("
学号: %s",student[i].id);
printf("
姓名: %s",student[i].name);
printf("
电话: %s",student[i].phone);
printf("
地址: %s",student[i].adress);
printf("
邮编: %s",student[i].postcode);
printf("
e-mail:%s",student[i].e_mail);

printf("");
if (i+1<num)
{
printf("
__________________________");
system("pause");
}
}
printf("
************************************************");
}
else
printf("
通讯录中无任何纪录");
printf("
按任意键返回主菜单:");
getch();
return;
}


//按电话查询
void searchbyphone()
{
int mark=0;
int i;
int a=0;
printf("
****************** 按电话查找 ******************");
char phone[10];
printf("
请输入学号:");
scanf("%s",phone);
for(i=0;i<num;i++)
{
if (strcmp(student[i].phone,phone)==0)
{
printf("
************** 以下是您查找的学生信息 **********");
printf("
学号: %s",student[i].id);
printf("
姓名: %s",student[i].name);
printf("
电话: %s",student[i].phone);
printf("
地址: %s",student[i].adress);
printf("
e-mail:%s",student[i].e_mail);
printf("
************************************************");
printf("
按任意键返回主菜单:");
mark++;
getch();
return;
}
}
if (mark==0)
{
printf("
没有改学生的信息");
printf("
按任意键返回主菜单");
getch();
return;
}
}
void searchbyname()//按姓名查询
{
int mark=0;
int i;
int a=0;
printf("
***************** 按姓名查找 *******************");
char name[20];
printf("
请输入姓名:");
scanf("%s",name);
for(i=a;i<num;i++)
{
if (strcmp(student[i].name,name)==0)
{
printf("
************* 以下是您查找的学生信息 ***********");
printf("
学号: %s",student[i].id);
printf("
姓名: %s",student[i].name);
printf("
电话: %s",student[i].phone);
printf("
地址: %s",student[i].adress);
printf("
e-mail:%s",student[i].e_mail);
printf("
************************************************");
mark++;
if ((i+1)<num)
{
printf("
是否继续查找相同名字的学生信息:(y/n)");
if (getch()=='y')
{
a=i;
continue;
}
else
return;
}
else
{
printf("
按任意键返回主菜单");
getch();
return;
}
}
}
if(mark!=0)
{
printf("
没有相同姓名的学生纪录");
printf("
按任意键返回主菜单");
getch();
return;
}
else
{
printf("
没有相同姓名的学生纪录");
printf("
按任意键返回主菜单");
getch();
return;
}
}
void searchbyid()//按学号查询
{
int mark=0;
int i;
int a=0;
printf("
****************** 按学号查找 ******************
");
char id[10];
printf("
请输入学号:");
scanf("%s",id);
for(i=0;i<num;i++)
{
if (strcmp(student[i].id,id)==0)
{
printf("
************** 以下是您查找的学生信息 **********");
printf("
学号: %s",student[i].id);
printf("
姓名: %s",student[i].name);
printf("
电话: %s",student[i].phone);
printf("
地址: %s",student[i].adress);
printf("
e-mail:%s",student[i].e_mail);
printf("
************************************************");
printf("
按任意键返回主菜单:");
mark++;
getch();
return;
}

}
if (mark==0)
{
printf("
没有改学生的信息");
printf("
按任意键返回主菜单");
getch();
return;
}
}
void writetofile()//写入文件
{
int i;
if ((fp=fopen("student.bin","wb"))==NULL)
{
printf("
文件打开失败");
}
for (i=0;i<num;i++)
{
if (fwrite(&student[i],sizeof(struct record),1,fp)!=1)
{
printf("
写入文件错误!
");
}
}
fclose(fp);
printf("
通讯录文件已保存");
printf("
按任意键退出程序
");
exit(0);

}
void deleteone()//删除单个
{
char choic;
printf("
1-按学号删除 2-按姓名删除");
printf("
请选择:");
choic=getch();
switch (choic)
{
case '1':deletebyid();break;
case '2':deletebyname();break;
}
}
void listbyname()//按姓名排序
{
int i,j;
struct record tmp;
for (i=1;i<num;i++)
{
if(strcmp(student[i].name,student[i-1].name)<0)
{
tmp=student[i];
j=i-1;
do
{
student[j+1]=student[j];
j--;
}while ((strcmp(tmp.name,student[j].name)=0));
student[j+1]=tmp;
}
}
printf("
排序成功,是否显示?(y/n)");
if (getch()=='y')
showall();
return;
}
void listbyid()//按学号排序
{
int i,j;
struct record tmp;
for (i=1;i<num;i++)
{
if(strcmp(student[i].id,student[i-1].id)<0)
{
tmp=student[i];
j=i-1;
do
{
student[j+1]=student[j];
j--;
}while ((strcmp(tmp.id,student[j].id)=0);
student[j+1]=tmp;
}
}
printf("
排序成功,是否显示?(y/n)");
if (getch()=='y')
showall();
return;
}
void listmenu()//排序菜单
{
char choic;
if(num==0)
{
printf("
对不起,文件中无任何纪录");
printf("
按任意键返回主菜单");
getch();
return;
}
system("cls");
printf("
******************* 排序菜单 *******************");
printf("
********** 1-按学号排序 2-按姓名排序 **********");
printf("
********** 3-返回主菜单 **********");
printf("
************************************************");
printf("
请选择:");
choic=getch();
switch(choic)
{
case '1':listbyid();break;
case '2':listbyname();break;
case '3':mainmenu();break;
default:mainmenu();break;
}
}

如果你平时有许多同学和朋友的信息,试试在电脑上编写一个我这样的通讯录。很方便的哟。 先新建一个工程,在“工具箱->右键->部件”添加“Microsoft windows common control 6.0”,然后在窗体上添加五个标签,“标题”分别为 “姓名、电话、Oicq、E-Mail、地址”;添加一个文本框(text1), 然后[复制/粘贴4次]使其成为控件数组;添加一个Listview控件(Listview1),在其属性框中,添加五个“列首”,“文本”值分别为“姓名、电话、Oicq、E-Mail、地址”,“查看属性”为 “3-lvwReport”, 选中“整行选择”,取消“隐藏选择”;添加两个按钮,其标题属性分别为“添加”、“删除”。添加如下代码:
Option Explicit
Dim fileName As String
Private Sub Command1_Click()
'将文本框中的信息添加到列表框中
Dim i As Integer
With ListView1.ListItems.Add()
.Text = Text1(0)
For i = 1 To 4
.SubItems(i) = Text1(i)
Next i
End With
End Sub

Private Sub Command2_Click()
'删除列表框中信息
If ListView1.ListItems.Count > 0 Then
If MsgBox("真的要删除吗?", vbQuestion + vbYesNo + vbDefaultButton2) = vbYes Then
ListView1.ListItems.Remove ListView1.SelectedItem.Index
End If
End If
End Sub

Private Sub Form_Load()
Dim tpStr As String, i As Integer
fileName = App.Path & "\data.txt"
If Dir(fileName) "" Then
'加载数据
Open fileName For Input As #1
Do While Not EOF(1)
With ListView1.ListItems.Add()
For i = 0 To 4
Line Input #1, tpStr
If i = 0 Then
.Text = tpStr
Else
.SubItems(i) = tpStr
End If
Next i
End With
Loop
Close #1
End If
End Sub

Private Sub Form_Unload(Cancel As Integer)
Dim i As Integer
Dim tpList As ListItem
'保存数据
Open fileName For Output As #1
For Each tpList In ListView1.ListItems
Print #1, tpList.Text
For i = 1 To 4
Print #1, tpList.SubItems(i)
Next i
Next tpList
Close #1
End Sub

本程序已在windows98+VB6.0环境下调试通过。

#include "stdlib.h"
#include "string.h"
#include "conio.h"
#include "stdio.h"
#include "dos.h"
FILE *fp;
int i; //i是全局变量 可代替length
struct address
{ char postnum[10];
char a[40]; //家庭地址
};
struct birthday
{ int year;
int month;
int day;
};
struct ffriend
{ int num; //序号
char name[20];
char sex;
char telephone[13];
struct birthday birthday;
struct address address;

}
friends[50];

void Load()
{
int j;
long k;
fp=fopen("friend.txt","a+"); //打开文件friend.txt
if(fp!=NULL)
{
for(i=1;i<50;i++)

{
j=fgetc(fp);
if(j==EOF) //判断是否到了文件尾
return;
k=i-1;
fseek(fp,k*sizeof(struct ffriend),SEEK_SET);
fread(&friends[i],sizeof(struct ffriend),1,fp); //从文件中读取一条记录
}

}
else
{
fp=fopen("friend.txt","w");
i=1;
}

}
void Show(int j)
{
// friends[j].num=i;
printf("\n\n\t编号-Nnumber: %3d",friends[j].num);
printf("\n\t姓名-Name:%-20s",friends[j].name);
printf("\n\t性别-Sex:%c",friends[j].sex);
printf("\n\t联系电话-Telephone:%-13s",friends[j].telephone);
printf("\n\t出生日期-Birthday:%4d-%2d-%3d",friends[j].birthday.year,friends[j].birthday.month,friends[j].birthday.day);
printf("\n\t邮编-Postnum:%-10s",friends[j].address.postnum);
printf("\n\t通信地址-address:%-40s",friends[j].address.a);
}
void Append(int j)
{
fflush(stdin); //区内清除文件缓冲区,文件以写方式打开时将缓冲容写入文件
//stdin是一个标准FILE*(文件型指针)指向通常是用键盘的输入的输入流
friends[j].num=j;
printf("\n\t\t\t序号-Number:%d",j);
printf("\n\t\t\t姓名-Name:");
scanf("%s",friends[j].name);
fflush(stdin); //为什么没有fflush(stdin); 的效果会自动跳过呢?
printf("\t\t\t性别-Sex(m/w):"); //为什么输入汉字男女也会自动跳过联系电话呢
scanf("%c",&friends[j].sex);
printf("\t\t\t联系电话-telephone:");
scanf("%s",friends[j].telephone);
printf("\t出生日期-birthday");
printf("\n\t\t\t年份-year:");
scanf("%d",&friends[j].birthday.year);
printf("\t\t\t月份-month:");
scanf("%d",&friends[j].birthday.month);
printf("\t\t\t日-day:");
scanf("%d",&friends[j].birthday.day);
printf("\t\t\t邮编-Postnumber:");
scanf("%s",friends[j].address.postnum);
printf("\t\t\t通信地址-Address:");
scanf("%s",friends[j].address.a);
getchar();
}
void Delete()
{
int k;
printf("\n\tDelete 序号-Number:");
scanf("%d",&k);
if(k<=i)
{
for(int j=k;j<i+1;j++) /*插入位置后的元素顺序后移*/
{
strcpy(friends[j].name,friends[j+1].name); /*交换元素内容*/
friends[j].sex=friends[j+1].sex;
strcpy(friends[j].telephone,friends[j+1].telephone);
friends[j].birthday.year=friends[j+1].birthday.year;
friends[j].birthday.month=friends[j+1].birthday.month;
friends[j].birthday.day=friends[j+1].birthday.day;
strcpy(friends[j].address.postnum,friends[j+1].address.postnum);
strcpy(friends[j].address.a,friends[j+1].address.a);

}
i--;
}
else
{
printf("输入的序号太大!");
}
}
void Modify(int j)
{
Append(j);
}
void Save()
{
int j;
fp=fopen("friend.txt","w");
for(j=1;j<=i;j++)
{
fwrite(&friends[j],sizeof(struct ffriend),1,fp);
}
fclose(fp);

}

void main()
{
int j;
char grade;
char searchname[10];
Load();
i--;
do
{
printf("\t\t\t\t简易通讯录\n\n");
printf("功能选择(Function choose)\n");
printf("\1A.读取(Read)\n");
printf("\2B.增添(Append)\n");
printf("\6C.插入(Insert)\n");
printf("\5D.删除(Delete)\n");
printf("\5E.查询(Search)\n");
printf("\6F.修改(Modify)\n");
printf("\2G.保存(Save)\n");
printf("\1H.退出(Quit)\n");
printf("请选择(Choice)\n注:输入A~H的大写字母\n");
scanf("%c",&grade);
switch(grade)
//加个大写和小写 都可以啊
{
case 'A': j=1; //显示功能
while(getchar()!=0x1b&&j<=i) //增添按Esc键退出
{
Show(j++);
printf("\n请按回车键继续!");
}
if(j-1<1)
{
printf("\n\t空文档,无任何记录-Empty Note\n");
printf("\n请按回车键继续!");
getchar();

}
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
break;
case 'B': //增加功能
while(i<=50) //增加按ESC键退出的功能
{
i++;
Append(i);
printf("\t是否继续增加?y/n");
//修改 加上else if 其他就跳出或强制打印出出错
char a=getchar();
if(a=='n'||a=='N')
break;
}
if(i==51)
printf("\n\t文档已满,无法增加记录-note full");
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
getchar();
break;
case 'C':
int k;
printf("\n\t输入要插入的位置:");
scanf("%d",&k);
j=i+1;
friends[j].num=j;
for(j;j>k;j--) //插入功能
{
strcpy(friends[j].name,friends[j-1].name); //数据后移
friends[j].sex=friends[j-1].sex;
strcpy(friends[j].telephone,friends[j-1].telephone);
friends[j].birthday.year=friends[j-1].birthday.year;
friends[j].birthday.month=friends[j-1].birthday.month;
friends[j].birthday.day=friends[j-1].birthday.day;
strcpy(friends[j].address.postnum,friends[j-1].address.postnum);
strcpy(friends[j].address.a,friends[j-1].address.a);

}
Append(k);
i++;
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
break;
case 'D': //删除功能 //增添随意删除多条记录的功能
Delete();
if(i<1)
printf("\n没有记录-No records\n");
printf("\n请按回车键继续!");
getchar();
getchar();
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
break;
case 'E': //查询功能
printf("\n\t请输入要查询记录的相关姓名:"); //增添查询按列号的
scanf("%s",searchname);
for(j=1;j<=i;j++)
{
if(strcmp(searchname,friends[j].name)==0) //比较字符串
{
Show(j);
break;
}
}
if(i<1)
{
printf("\n 没有您所查询的记录-No records");
printf("\n 请按回车键继续!");
getchar();
}
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
getchar();
break;
case 'F': //修改功能 / /增添按序列号查询
printf("\n\t请输入要修改记录的相关姓名:");
gets(searchname);
scanf("%s",searchname);
for(j=1;j<=i;j++)
{
if(strcmp(searchname,friends[j].name)==0) //比较字符串
{
Modify(j);
// getchar(); //加个输出确定修改吗
}
}
if(i<1) //修改功能
{ printf("\n 没有您所要修改的记录-No records");
printf("\n 请按回车键继续!");
getchar();
getchar();
}
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
break;
case 'G':
Save(); //存盘功能
getchar();
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
break;

case 'H': //退出功能
char x;
printf("是否保存?yes/no\n");
scanf("%s",&x);
//getchar();
// getchar();
if(x=='y')
{
Save();
exit(0);
}
else
exit(0);

default:
printf("\n\t输入有误,请输入正确的序列号!");
printf("\n请按回车键继续!");
getchar();
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
}
}while(1);
}

这个问题答案网上很多,这个地址就是http://wenku.baidu.com/view/92d3d138376baf1ffc4fad1a.html或#include 我也答过
#include "stdio.h" #include "stdlib.h" #include "string.h" #include "conio.h" #include "mem.h" #include "ctype.h" /#include "alloc.h" #define N 3 typedef struct z1
{
char no[11];
char name[15];
int score[N];
float sum;
float average;
int order;
struct z1 *next;
}STUDENT;

STUDENT *init();
STUDENT *create();
STUDENT *delete(STUDENT *h);
void print(STUDENT *h); /* 显示所有记录*/
void search(STUDENT *h); /*查找*/
void save(STUDENT *h); /*保存*/
STUDENT *load(); /*读入记录*/
void computer(STUDENT *h); /*计算总分和均分*/
STUDENT *insert(STUDENT *h); /*插入记录*/
void append(); /*追加记录*/
void copy(); /*复制文件*/
STUDENT *sort(STUDENT *h); /*排序*/
STUDENT *index(STUDENT *h); /*索引*/
void total(STUDENT *h); /*分类合计*/
int menu_select(); /*菜单函数*/
/******主函数开始*******/
main()
{
int i;
STUDENT *head; /*链表定义头指针*/
head=init(); /*初始化链表*/
clrscr(); /*清屏*/
for(;;) /*无限循环*/
{
switch(menu_select()) /*调用主菜单函数,返回值整数作开关语句的条件*/
{ /*值不同,执行的函数不同,break 不能省略*/
case 0:head=init();break;
case 1:head=create();break;
case 2:head=delete(head);break;
case 3:print(head);break; /*显示全部记录*/
case 4:search(head);break; /*查找记录*/
case 5:save(head);break; /*保存文件*/
case 6:head=load(); break; /*读文件*/
case 7:computer(head);break; /*计算总分和均分*/
case 8:head=insert(head); break; /*插入记录*/
case 9:copy();break; /*复制文件*/
case 10:head=sort(head);break; /*排序*/
case 11:append();break; /*追加记录*/
case 12:head=index(head);break; /*索引*/
case 13:total(head);break; /*分类合计*/
case 14:exit(0); /*如菜单返回值为14程序结束*/
}
}
}
/*菜单函数,返回值为整数*/
menu_select()
{
char *menu[]={"***************MENU***************", /*定义菜单字符串数组*/
" 0. init list", /*初始化*/
" 1. Enter list", /*输入记录*/
" 2. Delete a record from list", /*从表中删除记录*/
" 3. print list ", /*显示单链表中所有记录*/
" 4. Search record on name", /*按照姓名查找记录*/
" 5. Save the file", /*将单链表中记录保存到文件中*/
" 6. Load the file", /*从文件中读入记录*/
" 7. compute the score", /*计算所有学生的总分和均分*/
" 8. insert record to list ", /*插入记录到表中*/
" 9. copy the file to new file", /*复制文件*/
" 10. sort to make new file", /*排序*/
" 11. append record to file", /*追加记录到文件中*/
" 12. index on nomber", /*索引*/
" 13. total on nomber", /*分类合计*/
" 14. Quit"}; /*退出*/
char s[3]; /*以字符形式保存选择号*/
int c,i; /*定义整形变量*/
gotoxy(1,25); /*移动光标*/
printf("press any key enter menu......\n"); /*压任一键进入主菜单*/
getch(); /*输入任一键*/
clrscr(); /*清屏幕*/
gotoxy(1,1); /*移动光标*/
textcolor(YELLOW); /*设置文本显示颜色为黄色*/
textbackground(BLUE); /*设置背景颜色为蓝色*/
gotoxy(10,2); /*移动光标*/
putch(0xc9); /*输出左上角边框┏*/
for(i=1;i<44;i++)
putch(0xcd); /*输出上边框水平线*/
putch(0xbb); /*输出右上角边框 ┓*/
for(i=3;i<20;i++)
{
gotoxy(10,i);putch(0xba); /*输出左垂直线*/
gotoxy(54,i);putch(0xba);
} /*输出右垂直线*/
gotoxy(10,20);putch(0xc8); /*输出左上角边框┗*/
for(i=1;i<44;i++)
putch(0xcd); /*输出下边框水平线*/
putch(0xbc); /*输出右下角边框┛*/
window(11,3,53,19); /* 制作显示菜单的窗口,大小根据菜单条数设计*/
clrscr(); /*清屏*/
for(i=0;i<16;i++) /*输出主菜单数组*/
{
gotoxy(10,i+1);
cprintf("%s",menu[i]);
}
textbackground(BLACK); /*设置背景颜色为黑色*/
window(1,1,80,25); /*恢复原窗口大小*/
gotoxy(10,21); /*移动光标*/
do{
printf("\n Enter you choice(0~14):"); /*在菜单窗口外显示提示信息*/
scanf("%s",s); /*输入选择项*/
c=atoi(s); /*将输入的字符串转化为整形数*/
}while(c<0||c>14); /*选择项不在0~14之间重输*/
return c; /*返回选择项,主程序根据该数调用相应的函数*/
}
STUDENT *init()
{
return NULL;
}

/*创建链表*/
STUDENT *create()
{
int i; int s;
STUDENT *h=NULL,*info; /* STUDENT指向结构体的指针*/
for(;;)
{
info=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!info) /*如果指针info为空*/
{
printf("\nout of memory"); /*输出内存溢出*/
return NULL; /*返回空指针*/
}
inputs("enter no:",info->no,11); /*输入学号并校验*/
if(info->no[0]=='@') break; /*如果学号首字符为@则结束输入*/
inputs("enter name:",info->name,15); /*输入姓名,并进行校验*/
printf("please input %d score \n",N); /*提示开始输入成绩*/
s=0; /*计算每个学生的总分,初值为0*/
for(i=0;i<N;i++) /*N门课程循环N次*/
{
do{
printf("score%d:",i+1); /*提示输入第几门课程*/
scanf("%d",&info->score[i]);
if(info->score[i]>100||info->score[i]<0)
printf("bad data,repeat input\n");
}while(info->score[i]>100||info->score[i]<0);
s=s+info->score[i];
}
info->sum=s;
info->average=(float)s/N;
info->order=0;
info->next=h;
h=info; }
return(h); /*返回头指针*/
}
/*输入字符串,并进行长度验证*/
inputs(char *prompt, char *s, int count)
{
char p[255];
do{
printf(prompt); /*显示提示信息*/
scanf("%s",p); if(strlen(p)>count)printf("\n too long! \n"); }while(strlen(p)>count);
strcpy(s,p); }
void print(STUDENT *h)
{
int i=0; /* 统计记录条数*/
STUDENT *p; /*移动指针*/
clrscr(); /*清屏*/
p=h; /*初值为头指针*/
printf("\n\n\n****************************STUDENT********************************\n");
printf("|rec|nO | name | sc1| sc2| sc3| sum | ave |order|\n");
printf("|---|----------|---------------|----|----|----|--------|-------|-----|\n");
while(p!=NULL)
{
i++;
printf("|%3d |%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\n", i, p->no,p->name,p->score[0],p->score[1],
p->score[2],p->sum,p->average,p->order);
p=p->next;
}
printf("**********************************end*********************************\n");
}
/*删除记录*/
STUDENT *delete(STUDENT *h)
{
STUDENT *p,*q; /*p为查找到要删除的结点指针,q为其前驱指针*/
char s[11]; /*存放学号*/
clrscr(); /*清屏*/
printf("please deleted no\n"); /*显示提示信息*/
scanf("%s",s); /*输入要删除记录的学号*/
q=p=h; /*给q和p赋初值头指针*/
while(strcmp(p->no,s)&&p!=NULL) /*当记录的学号不是要找的,或指针不为空时*/
{
q=p; /*将p指针值赋给q作为p的前驱指针*/
p=p->next; /*将p指针指向下一条记录*/
}
if(p==NULL) /*如果p为空,说明链表中没有该结点*/
printf("\nlist no %s student\n",s);
else /*p不为空,显示找到的记录信息*/
{
printf("*****************************have found***************************\n");
printf("|no | name | sc1| sc2| sc3| sum | ave |order|\n");
printf("|----------|---------------|----|----|----|--------|-------|-----|\n");
printf("|%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\n", p->no,
p->name,p->score[0],p->score[1],p->score[2],p->sum,
p->average,p->order);
printf("********************************end*******************************\n");
getch(); /*压任一键后,开始删除*/
if(p==h) /*如果p==h,说明被删结点是头结点*/
h=p->next; /*修改头指针指向下一条记录*/
else
q->next=p->next; /*不是头指针,将p的后继结点作为q的后继结点*/
free(p); /*释放p所指结点空间*/
printf("\n have deleted No %s student\n",s);
printf("Don't forget save\n");/*提示删除后不要忘记保存文件*/
}
return(h); /*返回头指针*/
}
/*查找记录*/
void search(STUDENT *h)
{
STUDENT *p; char s[15]; clrscr();
printf("please enter name for search\n");
scanf("%s",s); /*输入姓名*/
p=h; /*将头指针赋给p*/
while(strcmp(p->name,s)&&p!=NULL) /*当记录的姓名不是要找的,或指针不为空时*/
p=p->next; /*移动指针,指向下一结点*/
if(p==NULL) /*如果指针为空*/
printf("\nlist no %s student\n",s); /*显示没有该学生*/
else /*显示找到的记录信息*/
{
printf("\n\n*****************************havefound***************************\n");
printf("|nO | name | sc1| sc2| sc3| sum | ave |order|\n");
printf("|----------|---------------|----|----|----|--------|-------|-----|\n");
printf("|%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\n", p->no,
p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);
printf("********************************end*******************************\n");
}
}
/*插入记录*/
STUDENT *insert(STUDENT *h)
{
STUDENT *p,*q,*info; /*p指向插入位置,q是其前驱,info指新插入记录*/
char s[11]; /*保存插入点位置的学号*/
int s1,i;
printf("please enter location before the no\n");
scanf("%s",s); /*输入插入点学号*/
printf("\nplease new record\n"); /*提示输入记录信息*/
info=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!info)
{
printf("\nout of memory"); /*如没有申请到,内存溢出*/
return NULL; /*返回空指针*/
}
inputs("enter no:",info->no,11); /*输入学号*/
inputs("enter name:",info->name,15); /*输入姓名*/
printf("please input %d score \n",N); /*提示输入分数*/
s1=0; /*保存新记录的总分,初值为0*/
for(i=0;i<N;i++) /*N门课程循环N次输入成绩*/
{
do{ /*对数据进行验证,保证在0~100之间*/
printf("score%d:",i+1);
scanf("%d",&info->score[i]);
if(info->score[i]>100||info->score[i]<0)
printf("bad data,repeat input\n");
}while(info->score[i]>100||info->score[i]<0);
s1=s1+info->score[i]; /*计算总分*/
}
info->sum=s1; /*将总分存入新记录中*/
info->average=(float)s1/N; /*计算均分*/
info->order=0; /*名次赋值0*/
info->next=NULL; /*设后继指针为空*/
p=h; /*将指针赋值给p*/
q=h; /*将指针赋值给q*/
while(strcmp(p->no,s)&&p!=NULL) /*查找插入位置*/
{
q=p; /*保存指针p,作为下一个p的前驱*/
p=p->next; /*将指针p后移*/
}
if(p==NULL) /*如果p指针为空,说明没有指定结点*/
if(p==h) /*同时p等于h,说明链表为空*/
h=info; /*新记录则为头结点*/
else
q->next=info; else
if(p==h) {
info->next=p; h=info; }
else
{
info->next=p; q->next=info;
}
printf("\n ----have inserted %s student----\n",info->name); printf("---Don't forget save---\n"); /*提示存盘*/
return(h); /*返回头指针*/
}
/*保存数据到文件*/
void save(STUDENT *h)
{
FILE *fp; /*定义指向文件的指针*/
STUDENT *p; /* 定义移动指针*/
char outfile[10]; /*保存输出文件名*/
printf("Enter outfile name,for example c:\\f1\\te.txt:\n"); /*提示文件名格式信息*/
scanf("%s",outfile);
if((fp=fopen(outfile,"wb"))==NULL) /*为输出打开一个二进制文件,如没有则建立*/
{
printf("can not open file\n");
exit(1);
}
printf("\nSaving file......\n"); /*打开文件,提示正在保存*/
p=h; /*移动指针从头指针开始*/
while(p!=NULL) /*如p不为空*/
{
fwrite(p,sizeof(STUDENT),1,fp);/*写入一条记录*/
p=p->next; /*指针后移*/
}
fclose(fp); /*关闭文件*/
printf("-----save success!!-----\n"); /*显示保存成功*/
}
/* 从文件读数据*/
STUDENT *load()
{
STUDENT *p,*q,*h=NULL; /*定义记录指针变量*/
FILE *fp; /* 定义指向文件的指针*/
char infile[10]; /*保存文件名*/
printf("Enter infile name,for example c:\\f1\\te.txt:\n"); scanf("%s",infile); /*输入文件名*/
if((fp=fopen(infile,"rb"))==NULL) /*打开一个二进制文件,为读方式*/
{
printf("can not open file\n"); /*如不能打开,则结束程序*/
exit(1);
}
printf("\n -----Loading file!-----\n");
p=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!p)
{
printf("out of memory!\n"); /*如没有申请到,则内存溢出*/
return h; /*返回空头指针*/
}
h=p; /*申请到空间,将其作为头指针*/
while(!feof(fp)) /*循环读数据直到文件尾结束*/
{
if(1!=fread(p,sizeof(STUDENT),1,fp))
break; /*如果没读到数据,跳出循环*/
p->next=(STUDENT *)malloc(sizeof(STUDENT)); /*为下一个结点申请空间*/
if(!p->next)
{
printf("out of memory!\n"); return h;
}
q=p; p=p->next; }
q->next=NULL; /*最后一个结点的后继指针为空*/
fclose(fp); /*关闭文件*/
printf("---You have success read data from file!!!---\n");
return h; /*返回头指针*/
}
/*追加记录到文件*/
void append()
{
FILE *fp; /*定义指向文件的指针*/
STUDENT *info; /*新记录指针*/
int s1,i;
char infile[10]; /*保存文件名*/
printf("\nplease new record\n");
info=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!info)
{
printf("\nout of memory"); /*没有申请到,内存溢出本函数结束*/
return ;
}
inputs("enter no:",info->no,11); /*调用inputs输入学号*/
inputs("enter name:",info->name,15); /*调用inputs输入姓名*/
printf("please input %d score \n",N); /*提示输入成绩*/
s1=0;
for(i=0;i<N;i++)
{
do{
printf("score%d:",i+1);
scanf("%d",&info->score[i]); /*输入成绩*/
if(info->score[i]>100||info->score[i]<0)printf("bad data,repeat input\n");
}while(info->score[i]>100||info->score[i]<0); /*成绩数据验证*/
s1=s1+info->score[i]; /*求总分*/
}
info->sum=s1; /*保存总分*/
info->average=(float)s1/N; /*求均分*/
info->order=0; /*名次初始值为0*/
info->next=NULL; /*将新记录后继指针赋值为空*/
printf("Enter infile name,for example c:\\f1\\te.txt:\n"); scanf("%s",infile); /*输入文件名*/
if((fp=fopen(infile,"ab"))==NULL) /*向二进制文件尾增加数据方式打开文件*/
{
printf("can not open file\n"); /*显示不能打开*/
exit(1); /*退出程序*/
}
printf("\n -----Appending record!-----\n");
if(1!=fwrite(info,sizeof(STUDENT),1,fp)) /*写文件操作*/
{
printf("-----file write error!-----\n");
return; /*返回*/
}
printf("-----append sucess!!----\n");
fclose(fp); /*关闭文件*/
}
/*文件拷贝*/
void copy()
{
char outfile[10],infile[10];
FILE *sfp,*tfp; /*源和目标文件指针*/
STUDENT *p=NULL; /*移动指针*/
clrscr(); /*清屏*/
printf("Enter infile name,for example c:\\f1\\te.txt:\n");
scanf("%s",infile); /*输入源文件名*/
if((sfp=fopen(infile,"rb"))==NULL) /*二进制读方式打开源文件*/
{
printf("can not open input file\n");
exit(0);
}
printf("Enter outfile name,for example c:\\f1\\te.txt:\n"); /*提示输入目标文件名*/
scanf("%s",outfile); /*输入目标文件名*/
if((tfp=fopen(outfile,"wb"))==NULL) /*二进制写方式打开目标文件*/
{
printf("can not open output file \n");
exit(0);
}
while(!feof(sfp)) /*读文件直到文件尾*/
{
if(1!=fread(p,sizeof(STUDENT),1,sfp))
break; /*块读*/
fwrite(p,sizeof(STUDENT),1,tfp); /*块写*/
}
fclose(sfp); /*关闭源文件*/
fclose(tfp); /*关闭目标文件*/
printf("you have success copy file!!!\n"); /*显示成功拷贝*/
}
/*排序*/
STUDENT *sort(STUDENT *h)
{
int i=0; /*保存名次*/
STUDENT *p,*q,*t,*h1; /*定义临时指针*/
h1=h->next; /*将原表的头指针所指的下一个结点作头指针*/
h->next=NULL; /*第一个结点为新表的头结点*/
while(h1!=NULL) /*当原表不为空时,进行排序*/
{
t=h1; /*取原表的头结点*/
h1=h1->next; /*原表头结点指针后移*/
p=h; /*设定移动指针p,从头指针开始*/
q=h; /*设定移动指针q做为p的前驱,初值为头指针*/
while(t->sum<p->sum&&p!=NULL) /*作总分比较*/
{
q=p; /*待排序点值小,则新表指针后移*/
p=p->next;
}
if(p==q) /*p==q,说明待排序点值大,应排在首位*/
{
t->next=p; /*待排序点的后继为p*/
h=t; /*新头结点为待排序点*/
}
else /*待排序点应插入在中间某个位置q和p之间,如p为空则是尾部*/
{
t->next=p; /*t的后继是p*/
q->next=t; /*q的后继是t*/
}
}
p=h; /*已排好序的头指针赋给p,准备填写名次*/
while(p!=NULL) /*当p不为空时,进行下列操作*/
{
i++; /*结点序号*/
p->order=i; /*将名次赋值*/
p=p->next; /*指针后移*/
}
printf("sort sucess!!!\n"); /*排序成功*/
return h; /*返回头指针*/
}
/*计算总分和均值*/
void computer(STUDENT *h)
{
STUDENT *p; /*定义移动指针*/
int i=0; /*保存记录条数初值为0*/
long s=0; /*总分初值为0*/
float average=0; /*均分初值为0*/
p=h; /*从头指针开始*/
while(p!=NULL) /*当p不为空时处理*/
{
s+=p->sum; /*累加总分*/
i++; /*统计记录条数*/
p=p->next; /*指针后移*/
}
average=(float)s/i;/* 求均分,均分为浮点数,总分为整数,所以做类型转换*/
printf("\n--All students sum score is:%ld average is %5.2f\n",s,average);
}
/*索引*/
STUDENT *index(STUDENT *h)
{
STUDENT *p,*q,*t,*h1; /*定义临时指针*/
h1=h->next; /*将原表的头指针所指的下一个结点作头指针*/
h->next=NULL; /*第一个结点为新表的头结点*/
while(h1!=NULL) /*当原表不为空时,进行排序*/
{
t=h1; /*取原表的头结点*/
h1=h1->next; /*原表头结点指针后移*/
p=h; /*设定移动指针p,从头指针开始*/
q=h; /*设定移动指针q做为p的前驱,初值为头指针*/
while(strcmp(t->no,p->no)>0&&p!=NULL) /*作学号比较*/
{
q=p; p=p->next;
}
if(p==q) /*p==q, {
t->next=p; h=t; }
else {
t->next=p; /*t的后继是p*/
q->next=t; /*q的后继是t*/
}
}
printf("index sucess!!!\n"); /*索引排序成功*/
return h; /*返回头指针*/
}
/*分类合计*/
void total(STUDENT *h)
{
STUDENT *p,*q; /*定义临时指针变量*/
char sno[9],qno[9],*ptr; /*保存班级号的*/
float s1,ave; /*保存总分和均分*/
int i; clrscr(); /*清屏*/
printf("\n\n *******************Total*****************\n");
printf("---class---------sum--------------average----\n");
p=h; while(p!=NULL)
{
memcpy(sno,p->no,8); /*从学号中取出班级号*/
sno[8]='\0'; /*做字符串结束标记*/
q=p->next; /*将指针指向待比较的记录*/
s1=p->sum; /*当前班级的总分初值为该班级的第一条记录总分*/
ave=p->average; /*当前班级的均分初值为该班级的第一条记录均分*/
i=1; /*统计当前班级人数*/
while(q!=NULL) /*内循环开始*/
{
memcpy(qno,q->no,8); /*读取班级号*/
qno[8]='\0'; /*做字符串结束标记*/
if(strcmp(qno,sno)==0) /*比较班级号*/
{
s1+=q->sum; /*累加总分*/
ave+=q->average; /*累加均分*/
i++; /*累加班级人数*/
q=q->next; /*指针指向下一条记录*/
}
else
break; }
printf("%s %10.2f %5.2f\n",sno,s1,ave/i);
if(q==NULL)
break; else
p=q; }
printf("---------------------------------------------\n");
}

#include <cstring>
#include <fstream>
#include <iostream>
using namespace std;
#define szSTR 64

struct STU {
char name[szSTR];//姓名
int gender;//性别,0-女,1-男
char address[szSTR];//地址
int postcode; //邮编
char phone[szSTR];//电话
char email[szSTR];//email
};

ostream & operator < (ostream & o, STU & s)
{
o.write((char*)&s, sizeof(s));
return o;
}

ostream & operator <<(ostream & o, STU & s)
{
o << s.name << '\t';
o << (s.gender ? "男":"女") << '\t';
o << s.address << '\t';
o << s.postcode << '\t';
o << s.phone << '\t';
o << s.email << endl;
return o;
}

istream & operator > (istream & i, STU & s)
{
i.read((char*)&s, sizeof(s));
return i;
}

istream & operator >>(istream & i, STU & s)
{
memset(&s, 0, sizeof(s));
cout << "请输入学生姓名:";
i >> s.name ;
cout << "请输入学生性别(输入一个非零的数表示男生,零表示女生):";
i >> s.gender ;
cout << "请输入家庭住址:";
i >> s.address ;
cout << "请输入邮政编码:";
i >> s.postcode ;
cout << "请输入联系电话:";
i >> s.phone ;
cout << "请输入电子邮件:";
i >> s.email ;
return i;
}

int locate(char * file, char * name, STU * s)
{
if(!file || !name) return -1;
ifstream f(file, ios_base::binary);
if(!f) return -1;
streampos p = 0;
while(!f.eof()) {
p = f.tellg();
f > *s;
if(strcmp(name, s->name )) continue;
f.close();
return (int)p;
}//end while
f.close ();
return -1;
}

void clear(char * file)
{
if(!file) return ;
STU s; char name[szSTR]="";
cout << "请输入要删除的学生姓名:";
cin >> name ;
int p = locate(file, name, &s );
if(p < 0) {
cout << "查无此人!" << endl;
return ;
}//end if
ofstream f(file, ios::binary);
f.seekp((streampos)p);
memset(&s, 0, sizeof(s));
f < s;
f.close ();
cout << "操作成功!" << endl;
}

void insert(char * file)
{
if(!file) return ;
STU s,t;
cin >> s;
int p = locate(file, s.name, &t);
if(p>-1) {
cout << "记录已存在,需要覆盖吗(y/n)?";
char c = 0;
cin >> c;
if(c != 'y' && c!= 'Y') {
cout << "操作已放弃" << endl;
return ;
}//end if
ofstream f(file, ios::binary);
f.seekp((streampos)p);
f < s;
f.close();
}else{
ofstream a(file, ios::binary|ios::app);
a < s;
a.close();
}//end if
cout << "操作成功!" << endl;
}

void query(char * file)
{
if(!file) return;
STU s; char name[szSTR] ="";
cout << "请输入要查询的学生姓名:";
cin >> name ;
int p = locate(file, name, &s);
if (p < 0)
cout << "查无此人!" << endl;
else
cout << s;
//end if
}

void print(char * file)
{
if(!file) return ;
ifstream f(file, ios::binary);
if(!f) return ;
cout << "姓名\t性别\t住址\t邮编\t手机\t电子邮件"<<endl;
cout << "---------------------------------------------------------------------" << endl;
STU s;
while(!f.eof()) {
memset(&s, 0, sizeof(s));
f.read((char*)&s, sizeof(s));
if(s.name[0]) cout << s;
}//end while
f.close();
cout << "---------------------------------------------------------------------" << endl;
}

struct TLink {
struct STU student;
struct TLink * next;
};
void sort_append(TLink ** root, STU & s)
{
if(!root) return ;
if(s.name[0] == 0) return ;
if(!*root) {
*root = new TLink;
memset(*root, 0, sizeof(TLink));
memcpy(*root, &s, sizeof(s));
return ;
}//end if
TLink * h = *root;
STU * t = (STU*)h;
int r = strcmp(s.name , t->name );
if( r == 0) return;
if( r < 0) {
h = new TLink;
memset(h, 0, sizeof(TLink));
memcpy(h, &s, sizeof(s));
h->next = *root;
*root = h;
return ;
}//end if
TLink * n = 0;
while(h) {
n = h->next ;
if(!n) {
n = new TLink;
memset(n, 0, sizeof(TLink));
memcpy(n, &s, sizeof(s));
h->next = n;
break ;
}//end if
t =(STU*)n;
r = strcmp(s.name , t->name );
if (r == 0) break;
if (r > 0) {
h = n;
continue;
}//end if
n = new TLink;
memset(n, 0, sizeof(TLink));
memcpy(n, &s, sizeof(s));
n->next = h->next ;
h->next = n;
break;
}//end while
}//end sort_append
void rsort(char * file)
{
if(!file) return;
TLink * root = 0; STU s;
ifstream f(file, ios::binary);
if (!f) return ;
while(!f.eof()) {
f.read((char*)&s, sizeof(s));
sort_append(&root, s);
}//end while
f.close ();
ofstream o(file, ios::binary);
if(!o) return ;
TLink * h = root;
while(h) {
o.write((char*)h, sizeof(s));
root = h->next ;
delete h;
h = root;
}//end while
o.close ();
cout << "排序已完成!请用“全部输出”命令进行查看!" <<endl;
}//end rsort

int main(void)
{
char file[] = "c:\\contact.txt";
int cmd = 0;
for(;;) {
cout << "欢迎使用学生通信簿!请选择:1-添加;2-查询;3-删除;4-排序;5-全部输出;0-退出" <<endl;
cin >> cmd;
switch(cmd) {
case 0: return 0;
case 1: insert(file); break;
case 2: query (file); break;
case 3: clear (file); break;
case 4: rsort (file); break;
case 5: print (file); break;
default: cout << "错误的选择,请重新输入!" <<endl; break;
}//end case
}
return 0;
}


C++语言程序设计通讯录管理程序要求: (1)能建立,修改和增删学生通讯录...
{ printf("\\t通讯录中没有此人!\\n");return(n);

用c语言程序设计一个学生通讯录系统
3)要求:建立两个结构体数组(或链表、文件),包括至少5个用户的必要信息,能对数据进行补充、修改。执行一个具体的功能之后,程序将重新显示菜单。3、要求:1)用C语言实现系统;2)函数功能要划分好(结构化程序设计);3)界面友好(良好的人机交互),加必要的注释;4)提供程序测试方案。 展开  我来答 2个回答 #...

C语言程序设计 通讯录系统管理
通讯录信息导入:完成用户从界面输入需要导入的文件路径名称,读取该文件的内容,保存入系统,并在界面上显示导入内容的功能。通讯录信息导出:完成用户从界面输入需要导出的文件路径名称,将系统中通讯录信息保存入文件中。通讯录信息删除:完成用户从界面输入需要的通讯录信息的姓名,并将其从系统中删除。三、详细设计1、数据...

C语言程序设计:通讯录程序设计
printf("\\n\\t邮编-Postnum:%-10s",friends[j].address.postnum);printf("\\n\\t通信地址-address:%-40s",friends[j].address.a);} void Append(int j){ fflush(stdin); \/\/区内清除文件缓冲区,文件以写方式打开时将缓冲容写入文件 \/\/stdin是一个标准FILE*(文件型指针)指向通常是用键盘的...

C语言程序设计——课程设计——通讯录管理系统
C语言程序设计课程设计任务书一、设计题目、内容及要求题目:通讯录程序设计设计一个实用的小型通讯录程序,具有查询和删除功能,并且能够打开或修改指定文件及将多个文件组成一个文件... C语言程序设计 课程设计任务书一、设计题目、内容及要求题目:通讯录程序设计设计一个实用的小型通讯录程序,具有查询和删除功能,并且能...

c语言程序设计——编一个通讯录管理程序:序号 姓名 电话 地址
简单通讯录管理程序,代码如下:#include <stdio.h> include <string.h> include <stdlib.h> typedef struct student ST;struct student { char stN[20];char stVal[128];char stNo[10];char stTel[12];ST next;};ST head = NULL;int ShowNode(){ char no[20]= {0};ST t;printf("...

C语言程序设计,通讯录管理系统
\/*【用C语言编写具有数据插入、修改、删除、显示和查询功能的电话薄管理程序】1、数据包括:人名、工作单位、电话号码和E-mail地址。2、可对记录中的姓名和电话号码进行修改。3、可增加或删除记录。4、可显示所有保存的记录。5、可按人名或电话号码进行查询。另:采用结构体数组和文件系统实现。结构体...

求c语言通讯录程序设计
求c语言通讯录程序设计 系统功能1建立一个学生通讯录,并实现对通讯录的插入修改删除排序和查询等操作2设计简单的字符菜单将上述功能组装起来,形成一个完整的系统3最好可以将通讯录的信息用文件方式保存,每... 系统功能1建立一个学生通讯录,并实现对通讯录的插入 修改 删除 排序和查询等操作2设计简单的字符菜单将...

C语言课程设计:个人通讯录管理程序
case 11:exit(0); \/*如返回值为11则程序结束*\/ } } } \/*菜单函数,函数返回值为整数,代表所选的菜单项*\/ menu_select(){ char s[80];int c;gotoxy(1,25);\/*将光标定为在第25行,第1列*\/ printf("press any key enter menu...\\n");\/*提示压任意键继续*\/ getch(); \/*读入...

急求一个C语言程序设计报告:1.通讯录管理系统 2.电子生词库系统 3。商 ...
写一个我这样的通讯录。很方便的哟。 先新建一个工程,在“工具箱->右键->部件”添加“Microsoft windows common control 6.0”,然后在窗体上添加五个标签,“标题”分别为 “姓名、电话、Oicq、E-Mail、地址”;添加一个文本框(text1), 然后[复制\/粘贴4次]使其成为控件数组;添加一个Listview...

册亨县19487108150: 如何用c语言设计一个通讯录
景娟盐酸: #include<stdio.h> #include<malloc.h> #include<string.h> typedef struct student { char address[20]; char name[20]; char mail[7];; char phone[10]; struct student *next; }LNode; void creat_list( LNode **h ) //输入联系人 { LNode * p; int i; char temp_...

册亨县19487108150: 用C语言设计一个通信录
景娟盐酸: //刚写的楼主参考参考~~~ #include <stdio.h> #include <stdlib.h> void putDetail(FILE *f) { char ch = ' '; scanf("%c",&ch); while (ch!='\n') { fputc(ch,f); scanf("%c",&ch); } fputc(ch,f); } void main() { int option = 3; char ch; char *s = new char[100]; while...

册亨县19487108150: C语言程序设计:设计一个程序来创建一个通讯录
景娟盐酸: 如果你平时有许多同学和朋友的信息,试试在电脑上编写一个我这样的通讯录.很方便的哟. 先新建一个工程,在“工具箱-&gt;右键-&gt;部件”添加“Microsoft windows common control 6.0”,然后在窗体上添加五个标签,“标题”分别为 ...

册亨县19487108150: c语言编写一个通讯录
景娟盐酸: 以前写了一个~ 给你看看吧~ ^_^#include "stdio.h" #define T 50 typedef struct {char name[20];char sex[10];char age[10];char address[30];char QQ[9];char telephone[12]; }ADDRESS; int Shuru(ADDRESS t[]); void Xianshi(ADDRESS t[],int...

册亨县19487108150: 用C语言. 编写一个“通讯录管理系统”程序 -
景娟盐酸: #include <stdio.h> #include <stdlib.h> #include <string.h> struct worker { char name[30]; //name职工姓名 char ID[10]; //ID职工编号 char sex[3]; int birth; int tel; char educ[10]; char addr[30]; char zhicheng[10]; int year; }; int dq(struct worker wo[]); void ...

册亨县19487108150: 用C语言. 编写一个“通讯录管理系统”程序 -
景娟盐酸: #include#include#include#define M 500struct Man //定义结构体{ char Name[8]; //名...

册亨县19487108150: C语言程序设计——课程设计——通讯录管理系统 -
景娟盐酸: /*10.3.2源程序*头文件(.h)include "stdio.h" /*I/O函数*/ #include "stdlib.h" /*标...

册亨县19487108150: C语言通讯录程序
景娟盐酸: 以前写了一个简单的:#include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; /*与malloc.h差不多*/ #include &lt;string.h&gt; #include &lt;iostream&gt; using namespace std;#define maxlen 15 struct persons {int num; /*定义结构体数组用于缓存数据*/ ...

册亨县19487108150: C语言 通讯录 程序整体设计说明
景娟盐酸: 既然是个通讯录就要有以下的功能:1.添加信息 2.查找信息 3.修改信息 4.删除信息 5.浏览信息 6.保存信息 设计思路就是根据这六个功能,编写相应的函数一一实现.比如刚开始要写个菜单函数,将这些选项一一列举出来,然后用switch语句跟输入的菜单编号而调用相应的函数,通过函数的调用将以上共嫩那个一一实现 至于数据结构就用结构体,里面主要包括姓名、电话号码、地址(也可以根据需要另外添加功能)等.

册亨县19487108150: c语言程序 通讯录 -
景娟盐酸: #include "stdio.h"#include "stdlib.h" #include "string.h" #define N 3 typedef struct student { char num[11]; char name[15]; char sex; char birth[1...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网