思维导图
1.使用多文件编辑
定义商品信息:商品名称,商品单价,商品购买个数,商品描述,循环输入购买的商品,按单价排序,输出商品信息,计算最贵的商品以及一共花了多少钱?
在create函数,请实现在堆区申请内存5个连续的内存
在input函数,请实现循环输入购买的商品
在bubble函数,请实现按单价排序
在Max函数,计算最贵的商品名称
在Money函数,计算共花了多少钱
在output函数,请实现输出
在free_space函数。实现释放堆区内存
head.h文件
#ifndef __head_h__
#define __head_h__
#include <stdio.h>
#include<string.h>
#include<stdlib.h>
typedef struct good
{
int xuhao;
char name[30];
int price;
int count;
char descibe[30];
}bake;
bake* create(bake *p);
int *input();
void output(bake *yg[],int n);
void bubble(bake *yg[],int n);
void max(bake *yg[],int n);
int money(bake *yg[],int n);
bake* free_space(bake *p);
#endif
h11.c自定义函数文件
#include"head.h"
bake* create(bake *p)
{
int i;
p=(bake*)malloc(sizeof(bake)*5);
p->xuhao=1;strcpy(p->name,"内存条");p->price=1000;p->count=4;strcpy(p->descibe,"16G内存条");
(p+1)->xuhao=2;strcpy((p+1)->name,"cpu");(p+1)->price=2000;(p+1)->count=1;strcpy((p+1)->descibe,"12900K");
(p+2)->xuhao=3;strcpy((p+2)->name,"显卡");(p+2)->price=5000;(p+2)->count=1;strcpy((p+2)->descibe,"4070");
(p+3)->xuhao=4;strcpy((p+3)->name,"硬盘");(p+3)->price=1500;(p+3)->count=4;strcpy((p+3)->descibe,"500G固态");
(p+4)->xuhao=5;strcpy((p+4)->name,"电源");(p+4)->price=500;(p+4)->count=1;strcpy((p+4)->descibe,"850W");
printf("商品序号\t商品名称\t商品单价\t商品数量\t商品描述\n");
for(i=0;i<5;i++)
{
printf("%d\t\t%s\t\t%d\t\t%d\t\t%s\t\n",(p+i)->xuhao,(p+i)->name,(p+i)->price,(p+i)->count,(p+i)->descibe);
}
return p;
}
int *input(int *p,int n)
{
for(int i=0;i<n;i++)
{
scanf("%d",p+i);
}
return p;
}
void output(bake *yg[],int n)
{
int i;
for(i=0;i<n;i++)
{
printf("%d\t\t%s\t\t%d\t\t%d\t\t%s\t\n",yg[i]->xuhao,yg[i]->name,yg[i]->price,yg[i]->count,yg[i]->descibe);
}
}
void bubble(bake *yg[],int n)
{
int i,j;
for(i=1;i<n;i++)
{
for(j=0;j<n-i;j++)
{
if(yg[j]->price>yg[j+1]->price)
{
bake *t=yg[j];
yg[j]=yg[j+1];
yg[j+1]=t;
}
}
}
printf("按单价排序为\n");
output(yg,n);
}
void max(bake *yg[],int n)
{
int i,num;
int m=yg[0]->price;
for(i=0;i<n;i++)
{
if(yg[i]->price>m)
{
m=yg[i]->price;
num=i;
}
}
printf("最贵的商品为%d号商品,价格为%d\n",num+1,m);
}
int money(bake *yg[],int n)
{
int i;
int sum=0;
for(i=0;i<n;i++)
{
sum+=yg[i]->price*yg[i]->count;
}
return sum;
}
bake* free_space(bake *p)
{
free(p);
p=NULL;
return p;
}
main.c主函数文件
#include "head.h"
int main(int argc, const char *argv[])
{
bake *p=create(p);
printf("请输入你要购买的商品数量");
int n,i;
scanf("%d",&n);
printf("请输入你要买的商品序号");
int a[n];
bake *yg[n];
int *q=input(a,n);
printf("你购买的商品为:\n");
printf("商品序号\t商品名称\t商品单价\t商品数量\t商品描述\n");
for(i=0;i<n;i++)
{
yg[i]=p+*(q+i)-1;
}
output(yg,n);
bubble(yg,n);
max(yg,n);
printf("合计: %-4d\n",money(yg,n));
p=free_space(p);
return 0;
}