卡牌游戏。

题目描述

你手上有n张卡牌,要求将其填入框中,使得结果最小。

每张卡有两面:即每张卡有两个数字。6不能当作9使用,同理,9也不能当作6使用。

框与框之间有计算符号。计算符号以-和+间隔

例如:当n=8时,填入的框格式为:-O+O-O+O-O+OO+O

填入卡牌时,不一定需要按照卡牌和框的顺序进行填写(即可以进行位置的调换)。

输入描述

第一行一个正整数n。

接下来n行:每行两个整数A和B,分别表示每张卡牌的正面和反面。

其中,n<5.105且A,Bi<107

输出描述

输出一行一个整数,表示最小结果

复制代码
import os
import sys

# 请在此输入您的代码
n=int(input())
card=[]
for _ in range(n):
  a,b=map(int,input().split())
  card.append((a,b))


card.sort(key=lambda x : x[0]+x[1],reverse=True) #卡牌正反相加,如果结果大的证明有一个数字很大,如果结果很小证明有个数字为负/很小

ans=0
#减去最大的,加上最小的得到结果最小
for i in range(len(card)):
  if i <len(card)//2:
    ans-=max(card[i][0],card[i][1]) #找出数字大的
  else:
    ans+=min(card[i][0],card[i][1])  #找出数字小的

print(ans)
相关推荐
BirdenT1 小时前
20260519紫题训练
c++·算法
Li emily6 小时前
解决了加密货币api多币种订阅时的数据乱序问题
人工智能·python·api·fastapi
csdn_aspnet6 小时前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
2301_781571426 小时前
Golang格式化输出占位符都有什么_Golang fmt占位符教程【通俗】
jvm·数据库·python
asdzx676 小时前
使用 Python 为 PDF 添加页码 (详细教程)
python·pdf·页码
谙弆悕博士6 小时前
【附C源码】从零实现C语言堆数据结构:原理、实现与应用
c语言·数据结构·算法··数据结构与算法
AI技术控7 小时前
《Transformers are Inherently Succinct》论文解读:从“能表达什么”到“多紧凑地表达”
人工智能·python·深度学习·机器学习·自然语言处理
金融大 k9 小时前
Python 全球指数监控面板:TickDB + REST + WebSocket 完整方案
python·websocket
啊哈哈121389 小时前
系统设计复盘:为什么 Agent 的 ReAct 循环必须内嵌确定性保护层——以 FitMind 健康助手的路由与步骤控制为例
人工智能·python·react
gaosushexiangji9 小时前
DIC系统推荐:基于千眼狼三维数字图像相关的无人机旋翼疲劳试验全场应变与位移测量
人工智能·算法