⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 gzgl-newest.c

📁 C语言源码
💻 C
📖 第 1 页 / 共 2 页
字号:
}
 return n;
}

/*修改记录。先按输入的职工编号查询到该记录,然后提示用户修改编号之外的值,编号不能修改*/
void Modify(ZGGZ tp[],int n)
{
char findmess[20];
int p=0;
if(n<=0)
{ system("cls");
  printf("\n=====>No employee record!\n");
  getchar();
  return ;
}
system("cls");
printf("modify employee recorder");
Disp(tp,n);
stringinput(findmess,10,"input the existing employee number:"); /*输入并检验该编号*/
p=Locate(tp,n,findmess,"num"); /*查询到该数组元素,并返回下标值*/
if(p!=-1) /*若p!=-1,表明已经找到该数组元素*/
{
   printf("Number:%s,\n",tp[p].num);
   printf("Name:%s,",tp[p].name);
   stringinput(tp[p].name,15,"input new name:");

   printf("jbgz:%8.2f,",tp[p].jbgz);
   tp[p].jbgz=numberinput("jbgz:");

   printf("jiangjin:%8.2f,",tp[p].jj);
   tp[p].jj=numberinput("jiangjin:");

   printf("koukuan:%8.2f,",tp[p].kk);
   tp[p].kk=numberinput("koukuan:");

   tp[n].yfgz=tp[n].jbgz+tp[n].jj-tp[n].kk;
   tp[n].sk=tp[n].yfgz*0.12;
   tp[n].sfgz=tp[n].yfgz-tp[n].sk;
   printf("\n=====>modify success!\n");
   getchar();
   Disp(tp,n);
   getchar();
   saveflag=1;
}
else
  {Nofind();
   getchar();
  }
return ;
}

/*插入记录:按职工编号查询到要插入的数组元素的位置,然后在该编号之后插入一个新数组元素。*/
int Insert(ZGGZ tp[],int n)
{
   char ch,num[10],s[10];  /*s[]保存插入点位置之前的编号,num[]保存输入的新记录的编号*/
   ZGGZ newinfo;
   int flag=0,i=0,kkk=0;
   system("cls");
   Disp(tp,n);
   while(1)
   { stringinput(s,10,"please input insert location  after the Number:");
     flag=0;i=0;
     while(i<n) /*查询该编号是否存在,flag=1表示该编号存在*/
     {
      if(strcmp(tp[i].num,s)==0)  {kkk=i;flag=1;break;}
      i++;
     }
      if(flag==1)
        break; /*若编号存在,则进行插入之前的新记录输入操作*/
     else
     {  getchar();
        printf("\n=====>The number %s is not existing,try again?(y/n):",s);
        scanf("%c",&ch);
        if(ch=='y'||ch=='Y')
         {continue;}
        else
          {return n;}
      }
   }
  /*以下新记录的输入操作与Add()相同*/

  while(1)
  { stringinput(num,10,"input new employee Number:");
    i=0;flag=0;
    while(i<n) /*查询该编号是否存在,flag=1表示该编号存在*/
     {
      if(strcmp(tp[i].num,num)==0)  {flag=1;break;}
      i++;
     }
       if(flag==1)
      {
       getchar();
       printf("\n=====>Sorry,The number %s is  existing,try again?(y/n):",num);
       scanf("%c",&ch);
       if(ch=='y'||ch=='Y')
       {continue;}
       else
       {return n;}
      }
      else
       break;
  }
  
  strcpy(newinfo.num,num); /*将字符串num拷贝到newinfo.num中*/
  stringinput(newinfo.name,15,"Name:");
  newinfo.jbgz=numberinput("jbgz:"); /*输入并检验jbgz*/
  newinfo.jj=numberinput("jiangjin:");         /*输入并检验jiangjin*/
  newinfo.kk=numberinput("koukuan:");      /*输入并检验koukuan*/
  newinfo.yfgz=newinfo.jbgz+newinfo.jj-newinfo.kk;      /*计算yfgz*/
  newinfo.sk=newinfo.yfgz*0.12;  /*计算sk*/
  newinfo.sfgz=newinfo.yfgz-newinfo.sk;
  saveflag=1; /*在main()有对该全局变量的判断,若为1,则进行存盘操作*/

 for(i=n-1;i>kkk;i--) /*从最后一个组织元素开始往向移一个元素位置*/
 { strcpy(tp[i+1].num,tp[i].num);
   strcpy(tp[i+1].name,tp[i].name);
   tp[i+1].jbgz=tp[i].jbgz;
   tp[i+1].jj=tp[i].jj;
   tp[i+1].kk=tp[i].kk;
   tp[i+1].yfgz=tp[i].yfgz;
   tp[i+1].sk=tp[i].sk;
   tp[i+1].sfgz=tp[i].sfgz;
 }
   strcpy(tp[kkk+1].num,newinfo.num);  /*在kkk的元素位置后插入新记录*/
   strcpy(tp[kkk+1].name,newinfo.name);
   tp[kkk+1].jbgz=newinfo.jbgz;
   tp[kkk+1].jj=newinfo.jj;
   tp[kkk+1].kk=newinfo.kk;
   tp[kkk+1].yfgz=newinfo.yfgz;
   tp[kkk+1].sk=newinfo.sk;
   tp[kkk+1].sfgz=newinfo.sfgz;
   n++;
   Disp(tp,n);
   printf("\n\n");
   getchar();
   return n;
}

/*统计公司的员工的工资在各等级的人数*/
void Tongji(ZGGZ tp[],int n)
{
int count10000=0,count5000=0,count2000=0,count0=0;
int i=0;
if(n<=0)
{ system("cls");
  printf("\n=====>Not employee record!\n");
  getchar();
  return ;
}
system("cls");
Disp(tp,n);
i=0;
while(i<n)
{
  if(tp[i].sfgz>=10000) {count10000++;i=i+1;continue;}  /*实发工资>10000*/
  if(tp[i].sfgz>=5000)  {count5000++;i=i+1;continue;}    /*5000<=实发工资<10000*/
  if(tp[i].sfgz>=2000)  {count2000++;i=i+1;continue;}    /*2000<=实发工资<5000*/
  if(tp[i].sfgz<2000)   {count0++;i=i+1;continue;}      /*实发工资<2000*/

}
printf("\n------------------------------the TongJi result--------------------------------\n");
printf("sfgz>=     10000:%d (ren)\n",count10000);
printf("5000<=sfgz<10000:%d (ren)\n",count5000);
printf("2000<=sfgz< 5000:%d (ren)\n",count2000);
printf("sfgz<       2000:%d (ren)\n",count0);
printf("-------------------------------------------------------------------------------\n");
printf("\n\npress any key to return");
getchar();
}

/*利用冒泡排序法实现数组的按实发工资字段的降序排序,从高到低*/
void Sort(ZGGZ tp[],int n)
{
int i=0,j=0,flag=0;
ZGGZ newinfo;
if(n<=0)
{ system("cls");
  printf("\n=====>Not employee record!\n");
  getchar();
  return ;
}
system("cls");
Disp(tp,n);  /*显示排序前的所有记录*/
for(i=0;i<n;i++)
{
  flag=0;
  for(j=0;j<n-1;j++)
   if((tp[j].sfgz<tp[j+1].sfgz))
    { flag=1;
      strcpy(newinfo.num,tp[j].num);  /*利用结构变量newinfo实现数组元素的交换*/
      strcpy(newinfo.name,tp[j].name);
      newinfo.jbgz=tp[j].jbgz;
      newinfo.jj=tp[j].jj;
      newinfo.kk=tp[j].kk;
      newinfo.yfgz=tp[j].yfgz;
      newinfo.sk=tp[j].sk;
      newinfo.sfgz=tp[j].sfgz;

      strcpy(tp[j].num,tp[j+1].num);
      strcpy(tp[j].name,tp[j+1].name);
      tp[j].jbgz=tp[j+1].jbgz;
      tp[j].jj=tp[j+1].jj;
      tp[j].kk=tp[j+1].kk;
      tp[j].yfgz=tp[j+1].yfgz;
      tp[j].sk=tp[j+1].sk;
      tp[j].sfgz=tp[j+1].sfgz;

      strcpy(tp[j+1].num,newinfo.num);
      strcpy(tp[j+1].name,newinfo.name);
      tp[j+1].jbgz=newinfo.jbgz;
      tp[j+1].jj=newinfo.jj;
      tp[j+1].kk=newinfo.kk;
      tp[j+1].yfgz=newinfo.yfgz;
      tp[j+1].sk=newinfo.sk;
      tp[j+1].sfgz=newinfo.sfgz;
     }
     if(flag==0) break;/*若标记flag=0,意味着没有交换了,排序已经完成*/
    }
      Disp(tp,n);  /*显示排序后的所有记录*/
      saveflag=1;
      printf("\n    =====>sort complete!\n");

}




/*数据存盘,若用户没有专门进行此操作且对数据有修改,在退出系统时, 会提示用户存盘*/
void Save(ZGGZ tp[],int n)
{
FILE* fp;
int i=0;
fp=fopen("c:\\zggz","wb");/*以只写方式打开二进制文件*/
if(fp==NULL) /*打开文件失败*/
{
  printf("\n=====>open file error!\n");
  getchar();
  return ;
}
for(i=0;i<n;i++)
{
  if(fwrite(&tp[i],sizeof(ZGGZ),1,fp)==1)/*每次写一条记录或一个结构数组元素至文件*/
  { 
   continue;
  }
  else
  {
   break;
  }
}
if(i>0)
{
  getchar();
  printf("\n\n=====>save file complete,total saved's record number is:%d\n",i);
  getchar();
  saveflag=0;
}
else
{system("cls");
 printf("the current link is empty,no employee record is saved!\n");
 getchar();
 }
fclose(fp); /*关闭此文件*/
}


void main()
{
  ZGGZ gz[N];         /*定义ZGGZ结构体*/
  FILE *fp;           /*文件指针*/
  int select;         /*保存选择结果变量*/
  char ch;            /*保存(y,Y,n,N)*/
  int count=0;        /*保存文件中的记录条数(或元素个数)*/
   
  fp=fopen("C:\\zggz","ab+");
  /*以追加方式打开二进制文件c:\zggz,可读可写,若此文件不存在,会创建此文件*/
  if(fp==NULL)
  {
    printf("\n=====>can not open file!\n");
    exit(0);
  }

while(!feof(fp))
{
   if(fread(&gz[count],sizeof(ZGGZ),1,fp)==1) /*一次从文件中读取一条职工工资记录*/
      count++;
}
fclose(fp); /*关闭文件*/
printf("\n==>open file sucess,the total records number is : %d.\n",count);
getchar();
menu();
while(1)
{
   system("cls");
   menu();
   printf("\n              Please Enter your choice(0~9):");    /*显示提示信息*/
   scanf("%d",&select);

  if(select==0)
  {
   if(saveflag==1) /*若对数组的数据有修改且未进行存盘操作,则此标志为1*/
   { getchar();
     printf("\n==>Whether save the modified record to file?(y/n):");
     scanf("%c",&ch);
     if(ch=='y'||ch=='Y')
       Save(gz,count);
   }
   printf("\n===>thank you for useness!");
   getchar();
   break;
  }

  switch(select)
  {
  case 1:count=Add(gz,count);break;       /*增加职工工资记录*/
  case 2:count=Del(gz,count);break;      /*删除职工工资记录*/
  case 3:Qur(gz,count);break;           /*查询职工工资记录*/
  case 4:Modify(gz,count);break;        /*修改职工工资记录*/
  case 5:count=Insert(gz,count);break;  /*插入职工工资记录*/
  case 6:Tongji(gz,count);break;       /*统计职工工资记录*/
  case 7:Sort(gz,count);break;        /*排序职工工资记录*/
  case 8:Save(gz,count);break;        /*保存职工工资记录*/
  case 9:system("cls");Disp(gz,count);break;         /*显示职工工资记录*/
  default: Wrong();getchar();break;        /*按键有误,必须为数值0-9*/
  }
 }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -