数据结构day2作业

本文介绍了如何在C语言中使用函数实现商品信息的输入、排序、价格计算和输出,包括在堆区申请内存、循环输入商品、按单价排序、计算最贵商品及总花费,并展示了内存管理的free_space函数。
摘要由CSDN通过智能技术生成

1.使用多文件编辑,

定义商品信息:商品名称,商品单价,商品购买个数,商品描述,循环输入购买的商品,按单价排序,输出商品信息,计算最贵的商品以及一共花了多少钱?

在create函数,请实现在堆区申请内存5个连续的内存

在input函数,请实现循环输入购买的商品

在bubble函数,请实现按单价排序

在Max函数,计算最贵的商品名称

在Money函数,计算共花了多少钱

在output函数,请实现输出

在free_space函数。实现释放堆区内存

//头文件
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
typedef struct goods 
{
	char name[10];
	float price;
	int num;
	char describe[20];
}s_g;


s_g *creat(int n);
void input(int n,s_g *p);
void Bubble(int n,s_g *p);
int  Max(int n,s_g *p);
float money(int n,s_g *p);
void outputs(int n,s_g *p,int m,float sum);
s_g *free_space(s_g *p);


//主函数
#include"head.h"

int main(int argc, const char *argv[])
{
	int n;
	printf("please enter n:");
	scanf("%d",&n);
	s_g *p=creat(n);

	input(n,p);
	
	Bubble(n,p);
 	int m=Max(n,p);
//	char max_name=(p+m)->name;
//	printf ("Max=%s\n",Name);

	float sum=money(n,p);
	
	outputs(n,p,m,sum);

//	printf ("sum=%.2f\n"sum);
	p=free_space(p);

	return 0;
}

#include"head.h"
s_g *creat(int n)
{
	s_g *p=(s_g*)malloc(sizeof(s_g)*n);
	if (p==NULL)
		return NULL;
	else
		return p;
}

void input(int n,s_g *p)
{
	for(int i=0;i<n;i++)
	{
		scanf("%s",(p+i)->name);
		scanf("%f",&(p+i)->price);
		scanf("%d",&(p+i)->num);
		scanf("%s",(p+i)->describe);
	}
}

void Bubble(int n,s_g *p)
{
	for(int i=1;i<n;i++)
	{
		for(int j=0;j<n-i;j++)
		{
			if((p+i)->price<(p+j+1)->price)
			{
				s_g t=*(p+j);
				*(p+j)=*(p+j+1);
				*(p+j+1)=t;
				
/*				float t=(p+j)->price;
				(p+j)->price=(p+j+1)->price;
				(p+j+1)->price=t;
*/
			}
		}
	}
}


int Max(int n,s_g *p)
{
	int t;
	int m=(p)->price;
	for(int i=0;i<n;i++)
	{
		if(m<(p+i)->price)
		{
			t=i;
		}
	}
	return t;
}


float money(int n,s_g *p)
{
	float sum=0;
	for(int i=0;i<n;i++)
	{
		sum+=(p+i)->price*(p+i)->num;
	}
	return sum;
}

void outputs(int n,s_g *p,int m,float sum)
{
	for (int i=0;i<n;i++)
	{
		printf("%s\t%.2f\t%d\t%s\n",(p+i)->name,(p+i)->price,(p+i)->num,(p+i)->describe);
		
	}
	printf ("Max=%s\n",(p+m)->name);
	printf ("sum=%.2f\n",sum);
}

s_g *free_space(s_g *p)
{
	if (NULL==p)
		return NULL;

	free(p);
	p=NULL;
	return p;
}

 

 

思维导图

 

  • 10
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值