#include "dos.h"
#include "iostream.h"
#include "conio.h"
#include "iostream.h"
#include "stdio.h" /*I/O函数*/
#include "stdlib.h" /*标准库函数*/
#include "string.h"/*字符串函数*/
#include "ctype.h" /*字符操作函数*/
#define M 200
typedef struct
{
char name[20];//名字
char num[20];//号码
char unit[30];//工作单位
}ADDERSS;
void gotoxy(int x,int y)//光标置位函数(x列y行)
{
int i,j;
for(i=0;i<=x;i++)
{printf("\n");}
for(j=0;j<=y;j++)
{printf(" ");}
}
/*输入纪录*/
int enter(ADDERSS t[])
{int i,n;
system("cls");//清屏
printf("请输入记录数\n");
cin>>n;
printf("请依次输入名字,单位,号码\n");
for(i=0;i<n;i++)
{
scanf("%s%s%s",t[i].name,t[i].unit,t[i].num);
printf("*********************************\n");
}
return n;
}
void list(ADDERSS t[],int n)
{int i;
system("cls");
printf("*************ADDERSS*****************\n");
printf("名字 单位 号码\n");
printf("------------------------------------\n");
for(i=0;i<n;i++)
printf("%-20s%-30s%-20s\n",t[i].name,t[i].unit,t[i].num);
if(i%10==0)
{printf("按任意键继续");
getch();
}
printf("**************the end****************\n");
system("pause");
}
int find(ADDERSS t[],int n,char *s)
{
int i;
for(i=0;i<n;i++)/*从第一条记录开始,直到最后一条*/
{
if(strcmp(s,t[i].name)==0) /*记录中的姓名和待比较的姓名是否相等*/
return i; /*相等,则返回该记录的下标号,程序提前结结束*/
}
return i; /*返回i值*/
}
void print(ADDERSS temp)
{
system("cls");
printf("\n\n************************************************\n");
printf("名字 单位 电话\n");
printf("----------------------------------------------------\n");
printf("%-20s%-30s%-20s\n",temp.name,temp.unit,temp.num);
printf("**********************end***********************\n");
system("pause");
}
void search(ADDERSS t[],int n)
{char s[20];
int i;
system("cls");
printf("请输入待查找名字\n");
scanf("%s",s);
i=find(t,n,s);
if(i>=n)
printf("找不到该文件");
else
print(t[i]);
}
int deletes(ADDERSS t[],int n)
{
char s[20]; /*要删除记录的姓名*/
int ch=0;
int i,j;
printf("请输入要删除记录的姓名\n"); /*提示信息*/
scanf("%s",s);/*输入姓名*/
i=find(t,n,s); /*调用find函数*/
if(i>n-1) /*如果i>n-1超过了数组的长度*/
printf("没找到要删除的记录\n"); /*显示没找到要删除的记录*/
else
{
print(t[i]); /*调用输出函数显示该条记录信息*/
printf("Are you sure delete it(1/0)\n"); /*确认是否要删除*/
scanf("%d",&ch); /*输入一个整数0或1*/
if(ch==1) /*如果确认删除整数为1*/
{
for(j=i+1;j<n;j++) /*删除该记录,实际后续记录前移*/
{
strcpy(t[j-1].name,t[j].name); /*将后一条记录的姓名拷贝到前一条*/
strcpy(t[j-1].unit,t[j].unit); /*将后一条记录的单位拷贝到前一条*/
strcpy(t[j-1].num,t[j].num); /*将后一条记录的电话拷贝到前一条*/
}
n--; /*记录数减1*/
}
}
return n; /*返回记录数*/
}
/*插入记录函数,参数为结构体数组和记录数*/
int add(ADDERSS t[],int n)/*插入函数,参数为结构体数组和记录数*/
{
ADDERSS temp; /*新插入记录信息*/
system("cls");
printf("请插入记录\n");
printf("请依次输入名字,工作单位,电话:\n");
scanf("%s%s%s",temp.name,temp.unit,temp.num); /*输入插入信息*/
strcpy(t[n+1].name,temp.name); /*将新插入记录的姓名拷贝到第n+1个位置*/
strcpy(t[n+1].unit,temp.unit); /*将新插入记录的单位拷贝到第n+1个位置*/
strcpy(t[n+1].num,temp.num); /*将新插入记录的电话拷贝到第n+1个位置*/
n++; /*记录数加1*/
return n; /*返回记录数*/
}
/*保存函数,参数为结构体数组和记录数*/
void save(ADDERSS t[],int n)
{
int i;
FILE *fp; /*指向文件的指针*/
if((fp=fopen("record.txt","wb"))==NULL) /*打开文件,并判断打开是否正常*/
{
printf("无法打开文件\n");/*没打开*/
exit(1); /*退出*/
}
printf("\n保存文件.......\n"); /*输出提示信息*/
fprintf(fp,"%d",n); /*将记录数写入文件*/
fprintf(fp,"\r\n"); /*将换行符号写入文件*/
for(i=0;i<n;i++)
{
fprintf(fp,"%-20s%-30s%-10s",t[i].name,t[i].unit,t[i].num);/*格式写入记录*/
fprintf(fp,"\r\n"); /*将换行符号写入文件*/
}
fclose(fp);/*关闭文件*/
printf("保存成功!!!\n"); /*显示保存成功*/
system("pause");
getch();
}
/*读入函数,参数为结构体数组*/
int load(ADDERSS t[])
{
int i,n;
FILE *fp; /*指向文件的指针*/
if((fp=fopen("record.txt","rb"))==NULL)/*打开文件*/
{
printf("不能打开文件\n"); /*不能打开*/
exit(1); /*退出*/
}
fscanf(fp,"%d",&n); /*读入记录数*/
for(i=0;i<n;i++)
fscanf(fp,"%20s%30s%10s",t[i].name,t[i].unit,t[i].num); /*按格式读入记录*/
fclose(fp); /*关闭文件*/
printf("你已经成功地从文件中读取了数据!!!\n"); /*显示保存成功*/
return n; /*返回记录数*/
system("pause");
}
/*按序号显示记录函数*/
void display(ADDERSS t[])
{
int id,n;
FILE *fp; /*指向文件的指针*/
if((fp=fopen("record.txt","rb"))==NULL) /*打开文件*/
{
printf("不能打开文件\n"); /*不能打开文件*/
exit(1); /*退出*/
}
printf("输入序号...\n"); /*显示信息*/
scanf("%d",&id); /*输入序号*/
fscanf(fp,"%d",&n); /*从文件读入记录数*/
if(id>=0&&id<n) /*判断序号是否在记录范围内*/
{
fseek(fp,(id-1)*sizeof(ADDERSS),1); /*移动文件指针到该记录位置*/
print(t[id]); /*调用输出函数显示该记录*/
printf("\r\n");
}
else
printf(" 序号%d不合理!!!\n ",id); /*如果序号不合理显示信息*/
fclose(fp); /*关闭文件*/
system("pause");
}
/*排序函数,参数为结构体数组和记录数*/
void sort(ADDERSS t[],int n)
{
int i,j,flag;
ADDERSS temp; /*临时变量做交换数据用*/
system("cls");
for(i=0;i<n;i++)
{
flag=0; /*设标志判断是否发生过交换*/
for(j=0;j<n-1;j++)
if((strcmp(t[j].name,t[j+1].name))>0) /*比较大小*/
{
flag=1;
strcpy(temp.name,t[j].name); /*交换记录*/
strcpy(temp.unit,t[j].unit);
strcpy(temp.num,t[j].num);
strcpy(t[j].name,t[j+1].name);
strcpy(t[j].unit,t[j+1].unit);
strcpy(t[j].num,t[j+1].num);
strcpy(t[j+1].name,temp.name);
strcpy(t[j+1].unit,temp.unit);
strcpy(t[j+1].num,temp.num) ;
}
if(flag==0)break; /*如果标志为0,说明没有发生过交换循环结束*/
}
printf("排序成功!!!\n");/*显示排序成功*/
system("pause");
}
/*快速查找,参数为结构体数组和记录数*/
void qseek(ADDERSS t[],int n)
{
char s[20];
int l,r,m;
system("cls");
printf("函数在查找之前已排序\n");/*提示确认在查找之前,记录是否已排序*/
printf("请输入要查找的名字\n"); /*提示输入*/
scanf("%s",s); /*输入待查找的姓名*/
l=0;r=n-1; /*设置左边界与右边界的初值*/
while(l<=r) /*当左边界<=右边界时*/
{
m=(l+r)/2; /*计算中间位置*/
if(strcmp(t[m].name,s)==0) /*与中间结点姓名字段做比较判是否相等*/
{
print(t[m]); /*如果相等,则调用print函数显示记录信息*/
return ; /*返回*/
}
if(strcmp(t[m].name,s)<0) /*如果中间结点小*/
l=m+1; /*修改左边界*/
else
r=m-1; /*否则,中间结点大,修改右边界*/
}
if(l>r) /*如果左边界大于右边界时*/
printf("not found\n"); /*显示没找到*/
system("pause");
}
/*复制文件*/
void copy()
{
char outfile[20]; /*目标文件名*/
int i,n;
ADDERSS temp[M]; /*定义临时变量*/
FILE *sfp,*tfp; /*定义指向文件的指针*/
system("cls");/*清屏*/
if((sfp=fopen("record.txt","rb"))==NULL) /*打开记录文件*/
{
printf("can not open file\n"); /*显示不能打开文件信息*/
exit(1); /*退出*/
}
printf("请输入文件的路径名,如 c:\\f1\\te.txt:\n"); /*提示信息*/
scanf("%s",outfile); /*输入目标文件名*/
if((tfp=fopen(outfile,"wb"))==NULL) /*打开目标文件*/
{
printf("不能打开文件\n"); /*显示不能打开文件信息*/
exit(1); /*退出*/
}
fscanf(sfp,"%d",&n); /*读出文件记录数*/
fprintf(tfp,"%d",n);/*写入目标文件数*/
fprintf(tfp,"\r\n"); /*写入换行符*/
for(i=0;i<n;i++)
{
fscanf(sfp,"%20s%30s%10s\n",temp[i].name,temp[i].unit,
temp[i].num); /*读入记录*/
fprintf(tfp,"%-20s%-30s%-10s\n",temp[i].name,
temp[i].unit,temp[i].num); /*写入记录*/
fprintf(tfp,"\r\n"); /*写入换行符*/
}
fclose(sfp); /*关闭源文件*/
fclose(tfp); /*关闭目标文件*/
printf("复制成功!!!\n"); /*显示复制成功*/
system("pause");
}
int menu_select()
{
char s[80];
int c;
system("cls"); /*清屏*/
gotoxy(5,1);
printf("******************菜单(容量200)**************\n\n");
printf(" 0. 输入记录\n");
printf(" 1. 显示记录函数\n");
printf(" 2. 按名字查找记录\n");
printf(" 3. 删除一个记录\n");
printf(" 4. 增加一个记录 \n");
printf(" 5. 保存该文件\n");
printf(" 6. 读入函数\n");
printf(" 7. 按序号显示记录函数\n");
printf(" 8. 排序函数\n");
printf(" 9. 快速查找\n");
printf(" 10. 复制文件\n");
printf(" 11. 退出\n");
gotoxy(5,1);
printf("*********************************************\n");
do{
printf("\n 输入选项(0~11):"); /*提示输入选项*/
scanf("%s",s); /*输入选择项*/
c=atoi(s); /*将输入的字符串转化为整型数*/
}while(c<0||c>11); /*选择项不在0~11之间重输*/
return c; /*返回选择项,主程序根据该数调用相应的函数*/
}
/******主函数开始*******/
void main()
{
ADDERSS adr[M]; /*定义结构体数组*/
int length; /*保存记录长度*/
system("cls"); /*清屏*/
for(;;)/*无限循环*/
{
switch(menu_select()) /*调用主菜单函数,返回值整数作开关语句的条件*/
{
case 0:length=enter(adr);
list(adr,length);
break;/*输入记录*/
case 1:list(adr,length);
break; /*显示全部记录*/
case 2:search(adr,length);
break; /*查找记录*/
case 3:length=deletes(adr,length);
list(adr,length);
break;/*删除记录*/
case 4:length=add(adr,length);
list(adr,length);
break; /*插入记录*/
case 5:save(adr,length);break; /*保存文件*/
case 6:length=load(adr); break; /*读文件*/
case 7:display(adr);break; /*按序号显示记录*/
case 8:sort(adr,length);break; /*按姓名排序*/
case 9:qseek(adr,length);break; /*快速查找记录*/
case 10:copy();break; /*复制文件*/
case 11:exit(0); /*如返回值为11则程序结束*/
}
}
}
在运行时插入会出现 乱码的现象,各位一试便知道,我也不好描述,
小弟先谢各位大哥大姐了