㈠ 谁能帮我用c语言做一个顺序表的超市管理系统,需要能进行增,删,改,查,插入,排序
typdef struct chao shi
{
char name[20];//商品名
int amount;//商品数量
double price;// 商品价格
struct chao shi*next;
}linklist;
linklist *creatlist();//创立链表return head;
void insert(linklist*p);//传入链表的首地址,插入函数ps:插入就是增加啊!
void change(linklist*p);//修改商品价格和数量!
void del(linklist*p);删除商品信息!
void sort(linklist*p);//排序
void find(linklist*p);//查找(里面包含输出)
void output(linklist*p);//输出函数
int menu()
void main()
ok!你自己会写了ba?我做了一个学生信息管理系统你看看吧可以参考下!
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define M 3
typedef struct node
{
char sno[20];
char name[20];
int score[M];
double avg;
struct node *next;
}linklist;
int listlength(linklist*head);
void output1(linklist*head);
void output2(linklist*head);
linklist *create()
{
linklist *head,*p,*t;
int n,i,j;
printf("请输入学生人数:");
scanf("%d",&n);
head=(linklist*)malloc(sizeof(linklist));
t=head;
for(i=0;i<n;i++)
{
p=(linklist*)malloc(sizeof(linklist));
printf("输入学号:");
scanf("%s",p->sno);
printf("输入姓名:");
scanf("%s",p->name);
printf("输入%d门功课成绩:",M);
for(j=0;j<M;j++)
scanf("%d",&p->score[j]);
printf("\n");
t->next=p;
t=p;
}
p->next=NULL;
return head;
}
void insert(linklist*head)
{
linklist *p;
int i,n,j;
printf("输入你要插入的学生人数:");
scanf("%d",&n);
printf("你要插入的学生信息:\n");
for(i=0;i<n;i++)
{p=(linklist*)malloc(sizeof(linklist));
p->next=head->next;
head->next=p;
printf("输入学号:");
scanf("%s",p->sno);
printf("输入姓名:");
scanf("%s",p->name);
printf("输入%d门功课成绩:",M);
for(j=0;j<M;j++)
scanf("%d",&p->score[j]);
}
}
void del(linklist*head)
{
linklist *p,*q;
char s[20];
printf("输入要删除学生的姓名:");
scanf("%s",s);
q=head;
p=head->next;
while(strcmp(p->name,s)!=0&&p)
{ q=p;
p=p->next;}
if(p==NULL)
printf("无此人\n");
else
{ q->next=p->next;
free(p);}
}
void change(linklist*head)
{
linklist*p;//修改学生信息模块!
int i,a[M];//M=3
char s[20];//存放学生姓名的数组!
printf("输入你要修改数据的学生姓名:");
scanf("%s",s);
p=head->next;
while(strcmp(p->name,s)!=0&&p)//遍历链表
p=p->next;
if(p==NULL)
printf("无此人\n");
else
{ printf("%s\t%s\t",p->sno,p->name);
printf("请重新输入学生的%d门成绩:",M);
for(i=0;i<M;i++)
{ scanf("%d",&a[i]);
p->score[i]=a[i];}
}
}
void sort(linklist*head)
{ double sum;//用学生的平均分进行排序!
linklist *p,*q,*t;
int i,j;
double temp;
int m=listlength(head);//求出链表长度的函数!(因为链表长度有变化所以写了这个函数)
q=p=head->next;
for(i=0;i<m;i++)
{
sum=0;
for(j=0;j<M;j++)//求出学生M门功课的成绩平均分
sum+=q->score[j];
p->avg=sum/M;
p=p->next;
q=p;
}
output2(head);
p=head->next;
printf("有不及格科目的学生:\n");
for(i=0;i<m;i++)
{ for(j=0;j<M;j++)
if(p->score[j]<60)
{ printf("%s\t%s\t",p->sno,p->name);
for(j=0;j<M;j++)
printf("%d ",p->score[j]);
printf("\n");
}
p=p->next;
}
printf("\n");
printf("学生成绩排序:\n");
t=NULL;
while(t!=head->next)
{
p=head;
q=p->next;
while(q->next!=t)
{
if(p->next->avg<q->next->avg)
{
p->next=q->next;
q->next=q->next->next;
p->next->next=q;
}
p=p->next;
q=p->next;
}
t=q;
}
}
int listlength(linklist*head)
{
int n=0;
linklist*p;
p=head->next;
while(p)
{n++;
p=p->next;
}
return n;
}
int menu()
{
int m,i;
printf("============================================================\n");
printf("||1:录入学生数据 2:增加学生数据 ||\n");
printf("||3:删除学生数据 4:改正学生数据 ||\n");
printf("||5:排序 6:退出。 ||\n");
printf("||=========================================================\n");
printf("输入你要选择的功能:");
i=scanf("%d",&m);
system("cls");
fflush(stdin);
return m;
}
void output1(linklist*head)
{
linklist*p;
int i;
p=head->next;
while(p)
{
printf("%s\t%s\t",p->sno,p->name);
for(i=0;i<M;i++)
printf("%d ",p->score[i]);
p=p->next;
printf("\n");
}
}
void output2(linklist*head)
{
linklist*p;
int i;
p=head->next;
while(p)
{
printf("%s\t%s\t",p->sno,p->name);
for(i=0;i<M;i++)
printf("%d ",p->score[i]);
printf("%lf",p->avg);
p=p->next;
printf("\n");
}
}
int main(void)
{
linklist*p;
int k=0;
do
{
k=menu();
switch(k)
{
case 1:
p=create();
output1(p);break;
case 2:insert(p);
output1(p);break;
case 3:del(p);
output1(p);break;
case 4:change(p);
output1(p);break;
case 5:sort(p);
output2(p);break;
case 6:exit(0);
}
}while(k>=1&&k<=6);
return 0;
}
㈡ 用C语言编写一简单的商品销售管理系统
第一个功能商品入库其实就是输入数据 不要想得太复杂 直接用scanf输入就可以了
第二个商品销售 就是改一下商品的数量
查询用折半查找顺序查找都可以 查到之后printf
排序可以用选择法
㈢ 使用C语言编程,对市场十种常见商品进行信息录入,并可实现排序输出功能 谢谢
很久以前大一刚入学时候做的商品管理系统,多文件结构,编译的时候编译Mainfile.c就行,当时还不懂事~用了goto语句,不过可以替换成循环【Datafile.c】#include <stdio.h>
#include <stdlib.h>/*文件*/
#include <malloc.h>/*链表*/
#include <conio.h>/*字体*/
#include "Headfile.h"
#define LEN sizeof(struct thing)
int n=0,m=0;/*主程序变量*/
struct thing *ha=NULL;/*主程序指针*/
FILE *fp=NULL;
struct thing/*商品数据*/
{
long d;
char name[10];
int num;
int mon;
long tol;
struct thing *next;
};
struct thing *creat(void)/*建立*/
{
struct thing *headc,*p1,*p2;
char q;
n=1;
p1=p2=(struct thing *)malloc(LEN);
C: printf("Creat A Ware->\n");
printf("Number:");
scanf("%ld",&p1->d);
printf("Name:");
scanf("%s",&p1->name);
printf("Quantity:");
scanf("%d",&p1->num);
printf("Price:");
scanf("%d",&p1->mon);
//printf("Sales Volume:");
//scanf("%ld",&p1->tol);
p1->tol=p1->num*p1->mon;
headc=NULL;/*头地址空*/
B: printf("--------------------\n");
printf("Mission Complete!\n");
printf("Creat Another Ware?\n");
printf("1.Yes\n");
printf("2.No\n");
printf("3.Quit System\n");
printf("Please Input Order:");
scanf("%s",&q);
printf("--------------------\n");
switch(q)
{
case 49:
if(n==1)
{
headc=p1;/*定义地址头*/
}
else
{
p2->next=p1;/*连接上一个地址*/
}
n=n+1;
p2=p1;
p1=(struct thing *)malloc(LEN);
printf("Creat A Ware->\n");
printf("Number:");
scanf("%ld",&p1->d);
printf("Name:");
scanf("%s",&p1->name);
printf("Quantity:");
scanf("%d",&p1->num);
printf("Price:");
scanf("%d",&p1->mon);
//printf("Sales Volume:");
//scanf("%ld",&p1->tol);
p1->tol=p1->num*p1->mon;
goto B;
case 50:
if(n==1)
{
headc=p1;
}
else
{
p2->next=p1;
}
p2=p1;
p1=(struct thing *)malloc(LEN);
p2->next=NULL;/*末地址空*/
printf("Please Wait...\n");
ha=headc;
return(headc);
case 51:
ha=headc;printf("Thank You!");ep();exit(0);break;
default:
printf("--------------------\nError!\n");
goto C;
}
}
void print(struct thing *headp)/*输出*/
{
struct thing *p;
printf("%d record:\n",n);
p=headp;/*指针转换*/
if(headp!=NULL)/*非空指针*/
{
do
{
printf("Number:%5ld Name:%10s Quantity:%5d Price:%5d Sales volume:%5ld\n",p->d,p->name,p->num,p->mon,p->tol);
p=p->next;
}while(p!=NULL);/*输出地址数据*/
}
printf("--------------------\nPlease Wait...\n");
}
struct thing *revise(struct thing *headr,long d)/*修改*/
{
struct thing *p1,*p2;
if(headr==NULL)/*头地址空*/
{
printf("No record!\n");
goto F;
}
p1=headr;/*地址转换*/
while(d!=p1->d&&p1->next!=NULL)/*找出符合条件的地址*/
{
p2=p1;
p1=p1->next;
}
if(d==p1->d)
{
printf("Revise The Ware->\n");
printf("Number:");
scanf("%ld",&p1->d);
printf("Name:");
scanf("%s",&p1->name);
printf("Quantity:");
scanf("%d",&p1->num);
printf("Price:");
scanf("%d",&p1->mon);
//printf("Sales Volume:");
//scanf("%ld",&p1->tol);
p1->tol=p1->num*p1->mon;
printf("Revise Complete!\n",d);
}
else
{
printf("Revise ware failure,ware not been found!\n");
}
F: return(headr);
}
struct thing *del(struct thing *headd,long d)/*删除*/
{
struct thing *p1,*p2;
if(headd==NULL)/*头地址空*/
{
printf("No record!\n");
goto end;
}
p1=headd;/*地址转换*/
while(d!=p1->d&&p1->next!=NULL)/*找出符合条件的地址*/
{
p2=p1;
p1=p1->next;
}
if(d==p1->d)
{
if(p1==headd)/*符合条件的地址为头地址*/
{
headd=p1->next;/*设定下个地址为头地址*/
}
else
{
p2->next=p1->next;/*连接间断地址*/
}
printf("Delete The %ld Number.\n",d);
n=n-1;
}
else
{
printf("Removed node failure,node not been found!\n");
}
end:return(headd);
}
struct thing *insert(struct thing *headi,struct thing *th)/*插入*/
{
struct thing *p0,*p1,*p2;
p1=headi;/*老数据地址*/
p0=th;/*新数据地址*/
if(headi==NULL)/*老数据地址为空*/
{
headi=p0;
p0->next=NULL;
}
else
{
while((p0->d>p1->d)&&(p1->next!=NULL))/*找出符合条件的地址*/
{
p2=p1;
p1=p1->next;
}
if(p0->d<=p1->d)
{
if(headi==p1)/*空数据*/
{
headi=p0;
}
else
{
p2->next=p0;
}
p0->next=p1;
}
else
{
p1->next=p0;/*连接老地址*/
p0->next=NULL;
}
}
n=n+1;
return(headi);
}
void run()/*加载文件*/
{
struct thing *h1;
FILE *fp;
h1=(struct thing *)malloc(LEN);
//fp=fopen("set_n","rb");
if((fp=fopen("set_n","rb"))==NULL)/*读取文件*/
{
//fp=fopen("set_n","wb+");
if((fp=fopen("set_n","wb+"))==NULL)/*如果没有则创建文件*/
{
printf("Error!\n");
exit(0);
}
printf("No Data.Please Creat A New!\n");
h1=creat();/*创建函数*/
save(h1,fp);
fclose(fp);
goto D;
}
load(fp);/*指针转换*/
D: fclose(fp);
}
void query()/*查询选项的函数*/
{
print(ha);
}
void add()/*增加选项的函数*/
{
struct thing *h3,*th;
printf("Input The Add Data:\n");
th=(struct thing *)malloc(LEN);
printf("Number:");
scanf("%ld",&th->d);
printf("Name:");
scanf("%s",&th->name);
printf("Quantity:");
scanf("%d",&th->num);
printf("Price:");
scanf("%d",&th->mon);
//printf("Sales Volume:");
//scanf("%ld",&th->tol);
th->tol=th->num*th->mon;
h3=insert(ha,th);/*增加函数*/
print(h3);
ha=h3;/*指针转换*/
}
void removed()/*删除选项的函数*/
{
struct thing *h4;
long dn;
printf("Input The Removed Number:");
scanf("%ld",&dn);
h4=del(ha,dn);/*删除函数*/
print(h4);
ha=h4;/*指针转换*/
}
void change()/*修改选项的函数*/
{
struct thing *h5;
long dr;
printf("Input The Wares Number You Want To Revise:");
scanf("%ld",&dr);
h5=revise(ha,dr);/*修改函数*/
print(h5);
ha=h5;/*指针转换*/
}
void ep()/*退出保存*/
{
FILE *fp;
fp=fopen("set_n","wb");
if((fp=fopen("set_n","wb"))==NULL)
{
printf("Error!");
exit(0);
}
save(ha,fp);
fclose(fp);
}
void save(struct thing *p,FILE*fp)/*保存函数*/
{
if(p!=NULL)
{
do
{
fwrite(p,LEN,1,fp);/*保存地址信息*/
p=p->next;
}while(p!=NULL);
}
printf("Save Data!\n");
}
void load(FILE *f)/*读取函数*/
{
struct thing *p1,*p2,*headl=NULL;
/*ha=(struct thing *)malloc(LEN);
if(fread(ha,LEN,1,f)!=1)
{
free(ha);
ha=NULL;
goto E;
}*/
p1=p2=(struct thing *)malloc(LEN);
while(fread(p1,LEN,1,f)!=0)/*读取文件*/
{
if(n==0)
{
headl=p1;
}
else
{
p2->next=p1;
}
p2=p1;
n++;
p1=(struct thing *)malloc(LEN);
}
p2->next=NULL;
ha=headl;
} 【Headfile.h】void run();
void query();
void add();
void removed();
void menu();
void save();
void ep();
void load();
void change();【Mainfile.c】#include <stdio.h>
#include <stdlib.h>/*文件*/
#include <malloc.h>/*链表*/
#include <conio.h>/*字体*/
#include "Headfile.h"
#include "Datafile.c"
void main()/*主函数*/
{
char i;
printf(" *************************************************************\n");
printf("\n");
printf(" ** Welcome! < Wares Management System > - XuHaiPing WarSki **\n");
printf("\n");
printf(" *************************************************************\n");
printf("\n\n\n");
run();/*初始化*/
A: printf("*********************\n");
printf("** 1.Query Wares **\n");
printf("** 2.Add Wares **\n");
printf("** 3.Removed Wares **\n");
printf("** 4.Revise Wares **\n");
printf("** 5.Save Wares **\n");
printf("** 6.Screen Clean **\n");
printf("** 7.Quit System **\n");
printf("*********************\n");
printf("Please Input Your Order:");
scanf("%s",&i);
switch(i)
{
case 49:printf("--------------------\nPlease Wait...\n");query();break;/*查询*/
case 50:printf("--------------------\nPlease Wait...\n");add();break;/*增加*/
case 51:printf("--------------------\nPlease Wait...\n");removed();break;/*删除*/
case 52:printf("--------------------\nPlease Wait...\n");change();break;/*修改*/
case 53:printf("--------------------\nPlease Wait...\n");ep();break;/*保存*/
case 54:system("cls");break;/*清屏*/
case 55:ep();printf("--------------------\nThank You!\n");exit(0);break;/*退出*/
default:printf("--------------------\nError!\n");goto A;/*返回*/
}
goto A;
}
㈣ C语言课程设计,商品库存管理系统怎么做啊
首先要创建数据库啊,也就是一个txt文件,要让里面有内容啊。其次是你的增加删除商品种类,修改指定商品的数目之类的,具体看老师的要求。
例程(基本框架,具体的操作需进一步开发):
#include<stdio.h>
#include<stdlib.h>
#include<conio.h>
#include<memory.h>
intcount=0;
structcommodity
{
intid;/*商品编号*/
intnumber;/*库存数量*/
intprice;/*单价*/
charname[20];/*商品名称*/
charindate[9];/*入库时间*/
chardeadline[9];/*有效日期*/
}a[100];
voidpage_title(char*menu_item)
{
printf("【商品库存管理系统】 ",menu_item);
}
voidreturn_confirm(void)
{
printf(" 按任意键返回…… ");
getch();
}
voidinsert(void)/*1插入*/
{
}
intsearch(void)/*2商品信息的查询*/
{
}
voiddel(void)/*3删除*/
{
}
voidsort()/*4排序*/
{
}
intmodify(void)/*5修改*/
{
}
intmain(void)
{menu:page_title("操作选单");
printf(" 1信息查询 2全部商品 ");
printf(" 3商品增加 4商品删除 ");
printf(" 5信息修改 0退出程序 ");
switch(getch())
{
case'1':search();break;
case'2':sort();break;
case'3':insert();break;
case'4':del();break;
case'5':modify();break;
case'0':exit(0);
}
gotomenu;
return0;
}
㈤ c语言设计商品信息管理系统
如果你不是为了学习用途,直接用蓝点产品管理系统好了,这些需求基本直接就实现了的。
㈥ 你好,C语言商品管理系统。已经有大概模版。求添加排序功能
排序其实挺简单的先包含头文件<string.h>用到比较函数stricmp();
if(stricmp(goods[i].xiaoshou,googs[i+1].xiaoshou)<0)//表示前一个销售小于后一个
{
char a[10];
strcpy(a,goods[i].xiaoshou);
strcpy(goods[i].xiaoshou,googs[i+1].xiaoshou);//交换值,让前面保存值较大的数
strcpy(googs[i+1].xiaoshou,a);
}
在这以上套用循环就可以了,我这样说你能理解吗
㈦ c语言商品管理系统
假设某超市经营各种商品,每种商品包括以下信息:商品编号、商品名称、商品品牌、库存数量、售价、已售数量。系统的主要功能包括:1. 创建商品信息文件:根据提示输入若干商品的信息,并将信息保存至一个文件中。2. 商品进货管理:每次购入新商品,需按要求输入商品所含各项信息并存入商品信息文件中。如果已经存在该商品(以商品编号为准),则修改相应的库存数量信息,否则生成新的商品信息记录。3. 商品销售管理:每次有商品销售出去,则按要求输入商品编号和商品名称信息,并修改相应的商品信息文件。注意:商品销售时要检查库存数量的合法性(即销售出去的数量必须小于库存数量)。4. 按不同条件进行查询操作,输出满足条件的商品信息。(1) 输入商品名称,在商品信息文件中查找相应的商品信息并输出。(2) 输入商品品牌,在商品信息文件中查找该品牌的所有信息并输出。5. 按不同条件对商品信息进行统计工作。(1) 输入商品名称,在商品信息文件中统计该商品的销售总额。(2) 设置一个库存数量警戒值,输出库存数量小于该警戒值的所有库存商品的信息。(3) 输入商品品牌,在商品信息文件中统计其不同商品名称的库存量,并输出库存量最高的那个商品的信息。
满意请采纳。
㈧ C语言 商品管理系统
好难!
㈨ C语言设计商品管理系统,可以实现商品的录入,查询,求源代码
#include <stdio.h>
#include <conio.h>
#include <string.h>
#define SIZE 300
typedef struct
{
char name[30];
int num;
char shang[10];
float price;
}record;
void DataInput(record *com, int *nptr);
int DataRead(record *com,int *nptr) ;
void DataStorage(record *com, int n); /*信息保存到文件*/
void DataFind( );
void DataDisPlay( );
void DataAdd( );
void DataDel( );
void DataStatistic( );
int main( )
{
record shangpin[SIZE];
int number=20; /*设商品数*/
char fn;
printf("\t~~~~~~商品管理系统~~~~~~");
while(1)
{
printf("\n\t\t1.商品信息录入\n"); /*显示主菜单*/
printf("\t\t2.商品信息显示\n");
printf("\t\t3.商品信息查找\n");
printf("\t\t4.商品信息添加\n");
printf("\t\t5.商品信息删除\n");
printf("\t\t6.商品信息统计\n");
printf("\t\t0.退出系统");
printf("\n\t~~~~~~~~~~~~~~~~\n");
printf("\t请输入你的一个选项(数字0-6): ");
fflush(stdin);
scanf("%c",&fn);
puts("\n");
switch(fn) /*切换到不同功能*/
{
case '1':
DataInput(shangpin, &number );
break; /*录入信息*/
case '2':DataDisPlay();
break; /*信息显示*/
case '3':
DataFind();
break; /*信息查找*/
case '4':
DataAdd( );
break; /*增加*/
case '5':
DataDel( );
break; /*删除*/
case '6':
DataStatistic();
break; /*信息统计*/
case '0':
return 0;
default:puts("\t\t没有这个项!返回主菜单!");
break;
}
printf("\n\t\t完毕!按任意键继续");
getch( );
puts("\n");
}
}
void DataInput(record *com, int *nptr) /*商品信息录入*/
{
int i = 0;
int n ; /*录入的总数*/
char YesOrNo; /*判断是否保存*/
char shangming[30]; /*商名*/
int haoma; /*商品号*/
char shangjia[10]; /*单价*/
float danjia;
printf("\t\t请输入商品个数:");
scanf("%d",&n);
*nptr = n; /*nptr返回商品个数*/
printf("\t\t现在开始录入这%d个商品信息:\n\n",n);
while(i<n)
{
printf("请输入商品的商品名:",i+1);
scanf("%s",&shangming);
printf("请输入商品的商品号:",i+1);
scanf("%d",&haoma);
printf("请输入商品的生产商:",i+1);
scanf("%s",&shangjia);
printf("请输入商品的单价 :",i+1);
scanf("%f",&danjia);
if(danjia>=0&&danjia<=1000) /*有效的单价才录入*/
{
strcpy(com[i].name,shangming);
com[i].num = haoma;
strcpy(com[i].shang,shangjia);
com[i].price = danjia;
i =i+1;
}
else
printf("输入的单价是一个无效的值!!!\n\n");
} /*结束while*/
printf("要保存您刚才录入的数据吗(Y/N)?"); /*选择保存*/
fflush(stdin);
scanf("%c",&YesOrNo);
if(YesOrNo=='y'||YesOrNo=='Y')
DataStorage(com,n);
else if(YesOrNo=='n'||YesOrNo=='N')
return;
else
printf("输入了不正确的选项\n");
return;
} /*结束函数*/
void DataFind( ) /*查找*/
{
void OnNumber(record *com,int n ); /*按商品号排序*/
int key; /*key为要查找的关键值*/
int low = 0; /*下限*/
int high ; /*上限*/
int mid ; /*中间值*/
char ans; /*选项*/
record com[SIZE];
int n;
if(DataRead(com,&n)==1) /*从文件中读取信息*/
{
OnNumber(com,n); /*先按商品号排序*/
high = n;
do
{
printf("\n\n\t\t请输入你要查找的商品号:");
scanf("%d",&key);
low = 0;high = n;
while (low <=high)
{
mid = (high + low)/2; /*折半查找法*/
if (key == com[mid].num )
{
printf("\n\t\t你要找的是第%d个商品\n",mid + 1);
printf("\t\t结果如下:\n\n");
printf("序号\t\t商品名\t 商品号\t生产商\t单价\n");
printf("%3d%17s%12d%12s%8.1f\n",mid+1,com[mid].name,com[mid].num,com[mid].shang,
com[mid].price);
break; /*如果找到则退出循环*/
}
if (key > com[mid].num ) low = mid + 1;
else high = mid - 1;
}
if (low > high)
printf("\t\t,没有找到这个价格!\n");
printf("\n\t\t还要继续查询吗(Y/N)?");
ans = getch( );
}
while (ans =='Y'||ans == 'y'); /*结束do....while*/
}
}
void DataStorage(record *com, int n) /*录入保存文件*/
{
int i;
FILE *comPtr;
char FileName[20];
printf("请输入您要保存的文件名:");
scanf("%s",FileName);
printf("正在将商品信息保存到文件,请稍候……\n");
if((comPtr=fopen(FileName,"w"))==NULL)
printf("没有该文件\n");
else
for(i=0 ; i<n ; i++)
fprintf(comPtr,"\n%17s%12d%12s%8.1f",com[i].name,com[i].num,com[i].shang,com[i].price);
fclose(comPtr);
}
int DataRead(record *com,int *nptr) /*读取文件*/
{
int i=0;
char datafile[20];
FILE *comPtr;
*nptr = 0;
printf("请输入文件名:");
scanf("%s",datafile);
if((comPtr = fopen(datafile,"r")) == NULL) /*打开文件*/
{
printf("没有该文件,请重新输入!\n");
return 0;
}
else
{
printf("正在读取商品单价,请稍候……\n");
while (!feof(comPtr))
{
fscanf(comPtr,"%s%d%s%f",&com[i].name,&com[i].num,&com[i].shang,&com[i].price);
i++;
}
*nptr = i;
printf("\n");
fclose(comPtr);
return 1;
}
}
void DataDisPlay()
{
void OnPrice(record *com,int n ); /*按单价*/
void OnNumber(record *com,int n ); /*按商品号*/
int N;
int i;
record com[300];
char YesNo; /*是否按顺序显示*/
char tp;
if(DataRead(com,&N)==1) /*从文件读取数据*/
{
printf("序号\t\t商品名\t 商品号\t生产商\t单价\n");
for(i=0;i<N;i++)
printf("%3d%17s%12d%12s%8.1f\n",i+1,com[i].name,com[i].num,com[i].shang,com[i].price);
printf("要按顺序显示吗?(Y/N)?");
fflush(stdin);
scanf("%c",&YesNo);
if(YesNo=='y'||YesNo=='Y')
{
printf("\t请输入排序方式:\n");
printf("\t(1.按价格排序从低到高;2.按商品号排序从低到高.)");
fflush(stdin);
scanf("%c",&tp);
if(tp=='1')
OnPrice(com,N);
else if(tp =='2')
OnNumber(com,N);
else
printf("\t输入了不正确项!\n");
}
}
} /*结束显示成绩*/
void OnPrice(record *com,int n ) /*按单价顺序*/
{ int i,j;
record temp;
printf("\t\t按单价排序---\n\n");
printf("商品总数为%d:\n",n);
for(j=0 ; j<n-1 ; j++) /*冒泡排序*/
for(i=0 ; i<n-j-1 ; i++)
if(com[i].price>com[i+1].price)
{
temp=com[i];
com[i]=com[i+1];
com[i+1]=temp;
}
printf("\n\t\t按成绩排序的结果如下(按分数从低到高):\n\n");
printf("序号\t\t商品名\t 商品号\t生产商\t单价\n");
for(i=0 ; i<n ; i++)
printf("%3d%17s%12d%12s%8.1f\n",i+1,com[i].name,com[i].num,com[i].shang,
com[i].price);
}
void OnNumber(record *com,int n ) /*按序号顺序*/
{
int i,j;
record temp;
printf("\t\t按商品号排序---\n\n");
printf("商品总数为%d:\n",n);
for(j=0 ; j<n-1 ; j++)
for(i=0 ; i<n-j-1 ; i++)
if(com[i].num>com[i+1].num)
{
temp=com[i];
com[i]=com[i+1];
com[i+1]=temp;
}
printf("\n\t按商品号排序的结果如下(按商品号从小到大):\n\n");
printf("序号\t\t商品名\t 商品号\t生产商\t单价\n");
for(i=0 ; i<n ; i++)
printf("%3d%17s%12d%12s%8.1f\n",i+1,com[i].name,com[i].num,com[i].shang,
com[i].price);
}
void DataAdd( ) /*增加*/
{
int i=0,n,m; /*商品名称*/
char shangming[30];
int haoma; /*生产商*/
char shangjia[10];
float danjia;
char YesOrNo;
record com[SIZE];
printf("\t\t读取原有数据信息---\n");
if(DataRead(com,&n)==1)
{
printf("\t\t信息读取完毕!\n\n");
printf("\t\t请输入要添加的商品总数:");
scanf("%d",&m);
printf("\t\t现在开始录入这%d个商品信息:\n\n",m);
while(i<m)
{
printf("第%d个商品的商品名:",i+1);
scanf("%s",&shangming);
printf("第%d个商品的商品号:",i+1);
scanf("%d",&haoma);
printf("第%d个商品的生产商:",i+1);
scanf("%s",&shangjia);
printf("第%d个商品的单价:",i+1);
scanf("%f",&danjia);
if(danjia>=0&&danjia<=1000) /*有效的单价才录入*/
{
strcpy(com[i+n].name,shangming);
com[i+n].num = haoma;
strcpy(com[i+n].shang,shangjia);
com[i+n].price = danjia;
i =i+1;
}
else
printf("输入的单价是一个无效的值,请重新输入!\n\n");
}
printf("要保存您刚才录入的数据吗(Y/N)?");
fflush(stdin);
scanf("%c",&YesOrNo);
if(YesOrNo=='y'||YesOrNo=='Y')
DataStorage(com,n+m);
else if(YesOrNo=='n'||YesOrNo=='N')
return;
else
printf("输入了不正确项,返回上一级\n");
return;
}
}
void DataDel( )//删除
{
void OnNumber(record *com,int n );
record com[SIZE];
int i; /*总记录数*/
int n; /*要删除的记录号*/
int m;
printf("\t\t读取原有数据信息---\n");
if(DataRead(com,&n)==1)
{
printf("\t\t原始数据如下:\n\n");
OnNumber(com,n );
printf("请输入你要删除的记录的序号");
scanf("%d",&m);
if(m>=1 && m<=n)
{
for(i=m-1;i<n-1;i++)
com [i] = com[i+1];
DataStorage(com,n-1);
}
}
}
void DataStatistic( ) /*统计信息*/
{
int high=0,low=200,ave=0;
int n,i,sum=0;
int g,l;
record com[SIZE];
printf("读取数据信息---\n");
if(DataRead(com,&n)==1)
{
printf("商品总数为%d\n\n",n);
for(i=0;i<n;i++)
{
if(com[i].price>high)
{
high = com[i].price;
g=i;
}
if(com[i].price<low)
{
low = com[i].price;
l=i;
}
sum += com[i].price;
}
ave=sum/n;
printf("\t\t最高\t最低\t平均\n"); /*计算值*/
printf("商品单价统计:\t%d\t%d\t%d\n\n",high,low,ave);
printf("序号\t\t商品名\t 商品号\t生产商\t单价\n");
for(i=0 ; i<n ; i++)
printf("%3d%17s%12d%12s%8.1f\n",i+1,com[i].name,com[i].num,com[i].shang,
com[i].price);
printf("\t\t 序号\t\t 商品名\t 商品号\t 生产商 单价\n");
printf("单价最高的商品是:%3d%17s%12d%12s%8.1f\n\n",g+1,com[g].name,com[g].num,com[g].shang,com[g].price);
printf("单价最低的商品是:%3d%17s%12d%12s%8.1f\n",l+1,com[l].name,com[l].num,com[l].shang,com[l].price);
} /*结束统计*/
}