#include <conio.h>
#include <stdlib.h>
//#include"FILE.h"
typedef struct shangpin
{
char name[20]
int biaohao
int shuliang
double jiage
}Node
typedef struct list
{
Node data
struct list *next
}List ,*Slist
void charu(Slist &s,Node x)
int caidan()
{
int i
while(1)
{
system("cls")
printf("\n\t\t\t商店销售管理系统\n\n")
printf("\t\t **********************************************\n\n")
printf("\t\t 1--添加商品 2--出售商品\n\n")
printf("\t\t 3--删除商品 4--显示商品\n\n")
printf("\t\t 5--查找商品 0--退出系统\n\n")
printf("\t\t **********************************************\n\n")
printf("请选择(0-5): ")
scanf("%d",&i)
if(i<6&&i>=0)break
}
return i
}
void chushihua(Slist &s)
{
Slist head=new List
head->next=NULL
s=head
}
void tianjia(Slist &s)
{
Node x
Slist r,p,q
int i=0
r=new List
r->next=NULL
q=p=s->next
while(q)
{
i++
q=q->next
}
printf("请输入商品名称、数量以及价格: ")
scanf("%s%d%lf",x.name,&x.shuliang,&x.jiage)
x.biaohao=i+1
r->data=x
s->next=r
r->next=p
}
void duchu(Slist &s)
{
FILE *cp//定义文件指针
int i=0
Node x
if((cp=fopen("shangpin.txt","a+"))==NULL)//打开文件
{printf("文件打开失败!")return }
fseek(cp,0L,SEEK_SET)//将文件指针移动到文件开头
while(!feof(cp))
{
fscanf(cp,"%s%d%lf",x.name,&x.shuliang,&x.jiage)//读取文件的内容
x.biaohao=++i
charu(s,x)//把读到的数据插入到链表上
}
fclose(cp)//关闭文件
}
void charu(Slist &s,Node x)
{
Slist r,p=s->next
r=new List
r->next=NULL
r->data=x
s->next=r
r->next=p
}
void xieru(Slist s)
{
FILE *cp//同上
Slist p=s->next
if((cp=fopen("shangpin.txt","w+"))==NULL)
{printf("文件打开失败!")return }//同上
while(p)
{
fprintf(cp,"%s %d %.2lf ",p->data.name,p->data.shuliang,p->data.jiage)//写入文件中,并且以空格隔开
p=p->next
}
fclose(cp)//关闭文件
}
Slist chazhao(Slist s,int m)
{
Slist p=s->next
if(p==0)return 0
if(p->next==0)return p
if(p->data.biaohao==m)return p
while(p->next)
{
if(p->next->data.biaohao==m)return p
p=p->next
}
return 0
}
void xianshi(Slist s)
{
Slist p
p=s->next
printf("%10s%20s%10s%10s\n","商品编号","商品名称","商品数量","商品价格")
while(p)
{
printf("%10d%20s%10d%10.2f\n",p->data.biaohao,p->data.name,p->data.shuliang,p->data.jiage)
p=p->next
}
}
void shanchu(Slist &s)
{
}
void chushou(Slist &s)
{
}
void main()
{
int num
Slist s
chushihua(s)
duchu(s)
num=caidan()
while(1)
{
switch(num)
{
case 0:exit(0)break
case 1:tianjia(s)break
case 2:chushou(s)break
case 3:shanchu(s)break
case 4:xianshi(s)break
case 5:chazhao(s,1)break
}
printf("按任意键继续!")
getch()()
num=caidan()
}
xieru(s)
}
这是我以前给别人的一个商品管理的,用文件存储,用的由头结点的链表存储数据的(不理解可以不管),你是拿这个自己改改不会问我呢?还是我直接给你改了?
下面的是我前几天刚针对这题目做的做的:#include "stdio.h"
#include "stdlib.h"
#include "string.h"
struct shebei
{
char ID[10]
char name[15]
char kind[15]
char over[15]
char yesno[10]
char time[10]
char price[10]
}
typedef struct node
{
struct shebei data
struct node *next //建立一个链表。
}Node
void Add(Node *equip) //添加记录
{
Node *p,*r,*s
char id[10]//先用于输入ID,也用于判断是否跳出循环
r=equip
s=equip->next //使s为第一个有用的结点
while(r->next!=NULL) //这个循环的作用是使r为最后一个有用的结点
r=r->next //将指针置于最末尾
while(1)
{
printf(">>>>>>>>>>提示:输入0则返回主菜单!\n")
printf("\n请你输入设备ID号:")
scanf("%s",id)
if(strcmp(id,"0")==0) break
p=(Node *)malloc(sizeof(Node)) //申请空间
strcpy(p->data.ID,id)
printf("\n请输入设备名称:")
scanf("%s",p->data.name)
printf("\n请输入设备种类:")
scanf("%s",p->data.kind)
printf("\n请输入报废日期:")
scanf("%s",&p->data.over)
printf("\n请输入设备是否报废:")
scanf("%s",&p->data.yesno)
printf("\n请输入设备购买时间:")
scanf("%s",&p->data.time)
printf("\n请输入设备价格:")
scanf("%s",&p->data.price)
printf(">>>>>>>>>>提示:已经完成一条记录的添加。\n")
p->next=NULL
r->next=p //这一步是必需的,将p与先前的链表连起来构成一条新链表
r=p//也是必需的.将r 又重设为新链的最后一个有用结点
}
}
void Modify(Node *equip)//修改
{
Node *p
char find[20]
if(!equip->next)
{
printf("\n>>>>>>>>>>提示:没有资料可以修改!\n")
return
}
printf("请输入要修改的设备ID号:")
scanf("%s",find)
p=equip->next
while(p!=NULL)
{
if(strcmp(p->data.ID,find)==0) //如果找到的话返回的是符合要求
break
p=p->next
}
if(p) //若找到
{
int x
while(1)
{
printf("完成修改请输入0否则输入任意数再进行修改:")
scanf("%d",&x)
if(x==0)
{break}
printf("请输入新设备号(原来是 %s ):",p->data.ID)
scanf("%s",p->data.ID)
printf("请输入新设备名称(原来是 %s ):",p->data.name)
scanf("%s",p->data.name)
printf("请输入新设备设备种类名称(原来是 %s ):",p->data.kind)
scanf("%s",p->data.kind)
printf("请输入新设备报废日期名称(原来是 %s ):",p->data.over)
scanf("%s",p->data.over)
printf("请输入新设备是否报废(原来是 %s ):",p->data.yesno)
scanf("%s",p->data.yesno)
printf("请输入新设备购买时间(原来是 %s ):",p->data.kind)
scanf("%s",p->data.time)
printf("请输入新设备价格(原来是 %s ):",p->data.price)
scanf("%s",p->data.price)
printf("\n>>>>>>>>>>提示:该项记录资料已经成功修改!\n")
}
}
elseprintf("\n>>>>>>>>>>提示:你要修改的信息不存在!\n")
}
void Disp(Node *equip)//输出记录
{
Node *p
p=equip->next
if(!p)
{
printf("\n>>>>>>>>>>提示:没有记录可以显示!\n")
return
}
printf("\t\t\t\t显示结果\n")
printf("设备号 设备名称 设备种类 报废日期 是否报废 购买时间 价格\n")
while(p)
{
printf("\n%-13s%-11s%-7s%-10s%-13s%-10s%-5s\n",p->data.ID,p->data.name,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price)
p=p->next
}
}
void Tongji(Node *equip)//统计
{
Node *p
int selint flag2=0,ha=0
p=equip->next
char find[20]
if(!equip->next) //若链表为空
{
printf("\n>>>>>>>>>>提示:没有资料可以统计分类!\n")
return
}
printf(">>>>>>>>>>提示:\n=====>0退出\n=====>1按设备号统计\n=====>2按设备名称统计\n")
scanf("%d",&sel)
if(sel==1)
{
printf("\n输入你要统计分类的设备号:")
scanf("%s",find)
while(p)
{
if(strcmp(p->data.ID,find)==0)
{
flag2++
}
if(flag2==1&&ha!=flag2)
{ printf("设备号 设备名称 设备种类 报废日期 是否报废 购买时间 价格\n")
printf("\n%-13s%-11s%-7s%-10s%-13s%-10s%-5s\n",p->data.ID,p->data.name,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price)
ha=flag2
}
else if(flag2>ha){printf("\n%-13s%-11s%-7s%-10s%-13s%-10s%-5s\n",p->data.ID,p->data.name,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price)ha=flag2}
p=p->next
}
if(flag2)
{
printf("\n*************************按设备号%s统计分类的有%d条记录:*************************\n\n",find,flag2)
}
else {printf("\n按设备号%s统计的结果为0个\n\n",find)}
}
else if(sel==2)
{
printf("\n输入你要统计分类的设备名称:")
scanf("%s",find)
while(p)
{
if(strcmp(p->data.name,find)==0)
{
flag2++
}
if(flag2==1&&ha!=flag2)
{ printf("设备号 设备名称 设备种类 报废日期 是否报废 购买时间 价格\n")
printf("\n%-13s%-11s%-7s%-10s%-13s%-10s%-5s\n",p->data.ID,p->data.name,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price)
ha=flag2
}
else if(flag2>ha){printf("\n%-13s%-11s%-7s%-10s%-13s%-10s%-5s\n",p->data.ID,p->data.name,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price)ha=flag2}
p=p->next
}
if(flag2)
{
printf("\n******************按设备名称%s统计的有%d条记录:********************\n\n",find,flag2)
}
else {printf("\n按设备名称%s统计分类的结果为0个\n\n",find)}
}
else if(sel==0) return
}
void main()
{
Node *equip
FILE *fp
int flag
Node *p,*q
printf("\t\t\t\t设备管理系统\n")
equip=(Node*)malloc(sizeof(Node))
equip->next=NULL
p=equip
fp=fopen("设备管理系统","wb+")
q=(Node*)malloc(sizeof(Node))
if(fread(q,sizeof(Node),1,fp)) //将文件的内容放入接点中
{
q->next=NULL
p->next=q
p=q//将该接点挂入链表中
}
fclose(fp)//关闭文件
while(1)
{
printf("**************************************目录**************************************")
printf("\n1添加记录\n")
printf("\n2修改记录\n")
printf("\n3显示记录\n")
printf("\n4统计分类记录\n")
printf("\n0*-EXIT-*\n")
printf("请输入你要操作的序号:")
scanf("%d",&flag)
switch(flag)
{
case 0: printf("\n>>>>>>>>>>提示:已经退出系统,ByeBye!\n")break
case 1: Add(equip) break//增加记录
case 2: Modify(equip) break//修改记录
case 3: Disp(equip) break//显示记录信息
case 4: Tongji(equip) break//统计记录
default:printf("\n>>>>>>>>>>提示:输入错误!\n")break
}
}
}
#include <stdio.h>#include <string.h>
typedef struct{
int qq
char string[1024]
}C语言
int main(){
C语言 c = {563337217, "计算机C语言课程设计有偿助攻,看清楚了有偿助攻再加好友!\n总有穷逼和傻逼想不花钱让爹给你白写,你TMD以为你是谁啊。\n想让爹给你白写的滚一边去,省的挨骂!"}
printf("QQ:%d\n%s\n", c.qq, c.string)
return 0
}