考研数据结构算法机试训练1

中南大学上机压轴题

测试数据:

复制代码
3 500
0.6 100
0.8 200
0.7 100
输出 390

首先要对输入的折扣进行排序,优先使用比率低的z进行支付。

然后用lowcost记录目前多少钱是打过折的。T-lowcost就是剩余没打折的。

每次循环用上一个人的折扣额度。若所有人折扣额度相加低于总价,则最后剩的部分就不打折

cpp 复制代码
#include <iostream>
using namespace std;

int paychase(int N,int T,double *z,int* H){
	int lowcost = 0;
	for(int i=0;i<N;i++){
		if(T<=lowcost+z[i]*H[i]){
			T = lowcost + (T-lowcost)*H[i];
			return T;
		}
		else{
			lowcost = lowcost + z[i]*H[i];
			cout<<"lowcost:"<<lowcost<<endl;
			T = T - H[i] + z[i]*H[i];
			cout<<"T:"<<T<<endl;
		}
	}
	return T;
}

int main(){
	int N,T;
	cout<<"请输入人数和菜品总价:"<<endl;
	cin>>N>>T;
	double z[N];
	int H[N];
	cout<<"请输入每个的折扣率和折扣上限:"<<endl;
	for(int i=0;i<N;i++){
		//cout<<i<<endl;
		cin>>z[i]>>H[i];
	}
	for (int i=0;i<N;i++){
		for (int j=i;j<N;j++){
			if(z[j]>z[i]){
				double tempz;int tempH;
				tempz=z[j];z[j]=z[i];z[i]=tempz;
				tempH=H[j];H[j]=H[i];H[i]=tempH;
			}
		}
	}
	int cost = paychase(N,T,z,H);
	cout<<"本次用餐总花费:"<<cost<<endl;
	return 0;
}
相关推荐
老蒋新思维12 分钟前
反脆弱性设计:创始人IP与AI智能体如何构建愈动荡愈强大的知识商业|创客匠人
人工智能·网络协议·tcp/ip·算法·机器学习·创始人ip·创客匠人
Salt_072816 分钟前
DAY 36 官方文档的阅读
python·算法·机器学习·github
FMRbpm29 分钟前
串练习--------535.TinyURL的加密和解密
数据结构·c++·新手入门
明洞日记1 小时前
【VTK手册027】VTK 颜色连续映射:vtkColorTransferFunction 深度解析与实战指南
c++·图像处理·算法·vtk·图形渲染
Bruce_kaizy1 小时前
c++单调数据结构————单调栈,单调队列
开发语言·数据结构·c++
阿坤带你走近大数据2 小时前
Python基础知识-数据结构篇
开发语言·数据结构·python
B_lack0262 小时前
西门子PLC结构化编程_线性插值算法功能块
算法·pid·西门子plc·博途·线性插值·开环控制
fufu03112 小时前
Linux环境下的C语言编程(四十三)
linux·c语言·算法
dragoooon342 小时前
[C++——lesson32.数据结构进阶——「初识哈希」]
数据结构·c++·哈希算法
业精于勤的牙2 小时前
三角形最小路径和(二)
算法