编程实现: 某商店搞促销活动“买二免一”,活动内容如下: 每买两件商品,结算时只收取其中价格高的商品费用,另一件商品不收取费用(相同价格只收取一件商品费用)。 小明选购了N件商品(2<=N<=1000,N为偶数),且已知每件商品的价格。请帮助小明,把商品进行两两组合,使得购买花费最少,并输出总费用。 例如: N=6,6件商品价格分别为32、56、92、45、12、98,共结算3次。 当98与92组合,56与45组合,32与12组合时,花费最少,总费用为186 (186=98+56+32)。输入描述 第一行输入一个正整数N (2<N≤1000,N为偶数),表示小明选购的商品数量 第二行输入N个正整数(1≤正整数≤100),表示每件商品的价格,正整数之间以一个英文逗号隔开输出描述 输出一个整数,表示购买N件商品最少需要花费的钱数 样例输入 编程实现: 某商店搞促销活动“买二免一”,活动内容如下: 每买两件商品,结算时只收取其中价格高的商品费用,另一件商品不收取费用(相同价格只收取一件商品费用)。 小明选购了N件商品(2<=N<=1000,N为偶数),且已知每件商品的价格。请帮助小明,把商品进行两两组合,使得购买花费最少,并输出总费用。 例如: N=6,6件商品价格分别为32、56、92、45、12、98,共结算3次。 当98与92组合,56与45组合,32与12组合时,花费最少,总费用为186 (186=98+56+32)。输入描述 第一行输入一个正整数N (2<N≤1000,N为偶数),表示小明选购的商品数量 第二行输入N个正整数(1≤正整数≤100),表示每件商品的价格,正整数之间以一个英文逗号隔开输出描述 输出一个整数,表示购买N件商品最少需要花费的钱数用代码怎么
时间: 2023-04-07 20:01:46 浏览: 350
实现这个问题可以使用贪心算法,将商品价格从小到大排序,然后每次取出两个价格最高的商品进行结算,将其中价格高的商品计入总费用,另一个商品不计入。重复这个过程直到所有商品都结算完毕。
以下是Python代码实现:
n = int(input())
prices = list(map(int, input().split(',')))
prices.sort()
total_cost = 0
for i in range(n//2):
total_cost += prices[n-1-i*2]
print(total_cost)
输出结果即为购买N件商品最少需要花费的钱数。