查看信息出现乱码如何解决?

作者在 2018-01-17 19:30:10 发布以下内容

附源代码:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<conio.h>
#define HEAD1 p->data.clss,p->data.name,p->data.xh,p->data.cyy,p->data.yy,p->data.wl,p->data.zy,p->data.ty
#define TITLE1 "|     班级     |  姓名 |   学号   | C语言 | 计算机英语 | 网络基础 | 职业生涯 | 体育 |\n"
#define TITLE2 "|%10s|%7s|%10s|%7s|%12s|%10s|%10s|%6s|\n"
#define TITLE3 "-------------------------------------------------------------------------------------\n"
#define MAX 20
struct book{
char clss[MAX];            /*班级*/
char name[MAX];            /*姓名*/
char xh[MAX];              /*学号*/
int cyy[MAX];                   /*C语言*/
int yy[MAX];                    /*计算机英语*/
int wl[MAX];                    /*网络基础*/
int zy[MAX];                    /*职业生涯*/
int ty[MAX];                    /*体育*/
};




typedef struct node
{
struct book data;
struct node *next;
}Node,*Link;












/*数据输出*/
void Output(Link head)
{




Node *p;




p=head->next;
if(p==NULL)
{
  printf("\n文件为空\n");
  getchar();




return ;
}
printf(TITLE3);
printf(TITLE1);
while(p!=NULL)
{




printf(TITLE3);
printf(TITLE2,HEAD1);
p=p->next;
}
printf(TITLE3);
printf("任意键返回...\n");






}












/*数据输入*/
void Input(Link head)     /*链表头做参数传入*/
{
int flag=1;         /*判断是否继续输入的变量*/
Node *p;
Node *ptr;
FILE *fp;
    Output(head);
fp=fopen("H:\\实力派(勿删).doc","a");
if(fp==NULL)
{
printf("file open error!");
        exit(0);
}
p=head;
ptr=p;






while(p->next!=NULL)
{
   p=p->next;         /*将指针移至于链表最末尾*/
   ptr=p;
    }
while(flag)
{
p=(Node*)malloc(sizeof(Node ));


printf("例如:17计算机高技班 谢某某 20150303 99 99 99 99 99\n");
printf("输入学生信息:班级,姓名,学号,C语言,计算机英语,网络基础,职业生涯,体育:\n");
scanf("%s %s %s %s %s %s %s %s",HEAD1);
printf("\n是否继续输入(1.YES,0.NO)");
scanf("%d",&flag);




fprintf(fp,"%s ",p->data.clss);      /*写入文件*/
fprintf(fp,"%s ",p->data.name);
fprintf(fp,"%s ",p->data.xh);
fprintf(fp,"%s ",p->data.cyy);
fprintf(fp,"%s ",p->data.yy);
fprintf(fp,"%s ",p->data.wl);
fprintf(fp,"%s ",p->data.zy);
fprintf(fp,"%s ",p->data.ty);








ptr->next=p;         /*将p写入链表*/
p->next=NULL;
ptr=ptr->next;


}
fclose(fp);   /*关闭文件*/
printf("任意键返回...\n");
}








/*学生信息查询函数*/
void Search(Link head)     /*链表头做参数传入*/
{
Node *p;
int choice;
int flag=0;              /*判断是否存在想要查询的信息*/
char xh[20];          /*存储学号的 变量*/
char name[20];       /*存储姓名的 变量*/




p=head->next;




printf("1:按学号查询  2:按姓名查询\n");
    printf("请选择(1 or 2):");
scanf("%d",&choice);
if(choice==1)              /*以学号搜索*/
{
printf("请输入学号:");
scanf("%s",xh);
while(p!=NULL)
{




if(strcmp(xh,p->data.xh)==0)       /*找到节点*/
{
printf(TITLE3);
printf(TITLE1);
printf(TITLE3);
printf(TITLE2,HEAD1);             /*输出节点内容*/
printf(TITLE3);


flag=1;
}
p=p->next;
}
if(flag==0)                  /*没有学生信息*/
printf("\n没有该学号信息\n");
printf("任意键返回...\n");


}
else
if(choice==2)    /*以姓名查询*/
{
printf("请输入姓名:");
scanf("%s",name);
while(p!=NULL)
   {




    if(strcmp(name,p->data.name)==0)       /*找到节点*/
{
printf(TITLE3);
  printf(TITLE1);
    printf(TITLE3);
    printf(TITLE2,HEAD1);    /*输出节点内容*/
printf(TITLE3);




flag=1;
}
    p=p->next;


}
if(flag==0)                        /*没有信息*/
    printf("\n没有该姓名信息\n");
    printf("任意键返回...\n");
}
else
printf("\n搞事情是吧!\n");      /*选择不为1或2,输出错误提示*/








}








/*数据信息更改*/
void Update(Link head)     /*链表头做参数传入*/
{
Node *p,*ptr;
FILE *fp;
int n=1;        /*判断是否继续更改*/
int flag=0;    /*判断学号是否存在的参数*/
char xh[20];             /*储存修改的学号*/
fp=fopen("H:\\实力派(勿删).doc","w");   /*文件打开*/
if(fp==NULL)
{
printf("File open error!");
getchar();
exit(0);
}




while(n!=0)
{


       p=head->next;
if(p==NULL)
{
printf("\n文件为空\n");
getchar();




return ;
}




   printf("输入你想的学号:");
   scanf("%s",&xh);










while(p!=NULL)
{


if(strcmp(xh,p->data.xh)==0)      /*找到节点*/
{
printf(TITLE3);
printf(TITLE1);
printf(TITLE3);
printf(TITLE2,HEAD1);         /*原有信息输出*/
   printf(TITLE3);
       printf("输入新的学生信息:班级,姓名,学号,C语言,计算机英语,网络基础,职业生涯,体育:\n");  /*更新内容*/
       scanf("%s %s %s %s %s %s %s %s",HEAD1);
   flag=1;
printf("是否继续更改(1.yes  0.no):");
scanf("%d",&n);




break;
}
p=p->next;




}
if(flag==0)            /*没有信息,提示*/
{
printf("没有改学号信息\n");
printf("是否继续更改(1.yes  0.no):");
scanf("%d",&n);
}
}




ptr=head->next;
while(ptr!=NULL)      /*重新将链表内容写入文件*/
{
fprintf(fp,"%s ",ptr->data.clss);
fprintf(fp,"%s ",ptr->data.name);
fprintf(fp,"%s ",ptr->data.xh);
fprintf(fp,"%s ",ptr->data.cyy);
fprintf(fp,"%s ",ptr->data.yy);
fprintf(fp,"%s ",ptr->data.wl);
fprintf(fp,"%s ",ptr->data.zy);
fprintf(fp,"%s ",ptr->data.ty);
ptr=ptr->next;


}




fclose(fp);   /*关闭文件*/
}




/*数据删除*/
void Delete(Link head)
{
FILE *fp;
Node *p,*ptr;
    char xh[20];
int flag=0;


fp=fopen("H:\\实力派(勿删).doc","w");   /*文件打开*/
if(fp==NULL)
{
printf("File open error!");
getchar();
exit(0);
}
ptr=head;
p=head->next;


printf("输入你想删除学生信息的学号:");   /*学号记录*/
scanf("%s",xh);
while(p!=NULL)
{
if(strcmp(xh,p->data.xh)==0)  /*找到删除信息的节点*/
{
ptr->next=p->next;                 /*实现删除功能*/
p->next=NULL;
free(p);                          /*释放p的内存*/
flag=1;         /*标志找到了此节点*/
break;
}
else
{
   ptr=p;
   p=p->next;
}
}
if(flag=0)        /*没有此信息,输出提示信息*/
printf("\n没有你想删除的学生信息.\n");




ptr=head->next;
while(ptr!=NULL)    /*链表内容重新写入文件*/
{
fprintf(fp,"%s ",ptr->data.clss);
fprintf(fp,"%s ",ptr->data.name);
fprintf(fp,"%s ",ptr->data.xh);
fprintf(fp,"%s ",ptr->data.cyy);
fprintf(fp,"%s ",ptr->data.yy);
fprintf(fp,"%s ",ptr->data.wl);
fprintf(fp,"%s ",ptr->data.zy);
fprintf(fp,"%s ",ptr->data.ty);
ptr=ptr->next;
}
}












/*选择错误提醒函数*/
void wrong()
{
printf("\n操作错误!!!\n");
}






void banben(Link head)  /*版本信息*/
 {
     printf("\n");
     printf("\n");
    printf("                                                        本软件开发时间为2018年1月8日           \n");
    printf("                                                     Copyright 2018[17计算机高技班创建]        \n");
    printf("                                                       本软件所有的版权均属于飞哥认证          \n");
    printf("                                             最终版权归计算机高技班所有,如有侵犯将追究法律责任\n");
}








/*菜单函数*/
void menu()
{
    printf("                                             ===========*|----------|*===========\n");
    printf("                                             ============|实力派 2.0|============\n");
printf("                                             ============|欢迎**使用|============\n");
printf("                                             ===========*|----------|*===========\n");
printf("                                             ------------------------------------\n");
printf("                                             |          1.录入学生信息          |\n");
printf("                                             ------------------------------------\n");
printf("                                             |          2.查看学生信息          |\n");
printf("                                             ------------------------------------\n");
printf("                                             |          3.查询学生信息          |\n");
printf("                                             ------------------------------------\n");
printf("                                             |          4.修改学生信息          |\n");
printf("                                             ------------------------------------\n");
printf("                                             |          5.删除学生信息          |\n");
printf("                                             ------------------------------------\n");
printf("                                             |          6.版本信息              |\n");
printf("                                             ------------------------------------\n");
printf("                                             |          0.退出                  |\n");
printf("                                             ------------------------------------\n");
}






/*main 函数*/
int main(void)
{
Link head;
int choice=1;
Node *p;
Node *tail;
FILE *fp;


fp=fopen("H:\\实力派(勿删).doc","a+");




if(fp==NULL)    /*打开文件*/
{
printf("FILE open error!\n");
exit(0);
}








head=(Node*)malloc(sizeof(Node));     /*链表头建立*/
    if(!head)
    {
      printf("\n allocate memory failure ");  /*如没有申请到,打印提示信息*/
      return 0;                       /*返回主界面*/
     }


head->next=NULL;
tail=head;










while(fgetc(fp)!=EOF)
{
fseek(fp,-1,1);


p=(Node*)malloc(sizeof(Node));


if(!p)
{
printf("\n allocate memory failure!\n");
return 0;
}
fscanf(fp,"%s",p->data.clss);
fscanf(fp,"%s",p->data.name);
fscanf(fp,"%s",p->data.xh);
fscanf(fp,"%s",&p->data.cyy);
fscanf(fp,"%s",&p->data.yy);
fscanf(fp,"%s",&p->data.wl);
fscanf(fp,"%s",&p->data.zy);
fscanf(fp,"%s",&p->data.ty);


p->next=NULL;
tail->next=p;
tail=p;
}
fclose(fp); /*关闭文件*/






    while(1)
{
   menu();
   printf("                                             请输入你的操作序号(0--6):");  /*选择操作*/
   scanf("%d",&choice);
if(choice==0)                /*如果选择0,退出*/
{




printf("                                             感谢你的使用,再见!\n");
printf("                                             按任意键退出...\n");
getchar();
   break;
}
switch(choice)
{
case 1:Input(head);break;
case 2:Output(head);getch();break;
case 3:Search(head);getch();break;
case 4:Update(head);getch();break;
case 5:Delete(head);getch();break;
case 6:banben(head);getch();break;
default:wrong();break;
}
}




getchar();


return 0;
}


1.png (上传于2018-01-17 19:30:10)
1.png
默认分类 | 阅读 1472 次
文章评论,共0条
游客请输入验证码
文章分类
文章归档
最新评论