day2:结构体应用

思维导图

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;
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值