有货车运量V;有若干物品A 占2单位体积,有若干物品B占1单位体积;相同种类的物品价值不一定一样;

序号按照输入顺序而定;问货车可以拉走最多多少价值的物品,并输出所选物品的序号;

1)常规的解法思路:贪心,先把A填到不能填,然后再补B,补完B后再考虑用B去替换前面A,此策略必定最优;考虑到B物品的可补行!因为涉及变量较多,时刻注意A,B,空余V的数量关系;代码如下:

n,v = map(int,input().split())
l1 = []
l2 = []
for i in range(n):
    t,x = map(int,input().split())
    if t == 1:
        l1.append([x,i+1])
    else:
        l2.append([x,i+1])
l1.sort(reverse=True)
l2.sort(reverse=True)

s1 = [0]
s2 = [0]
for i in range(min(v,len(l1))):
    s1.append(s1[-1]+l1[i][0])
for i in range(min(int(v/2),len(l2))):
    s2.append(s2[-1]+l2[i][0])
ans = 0
num = 0
# print(s1)
# print(s2)
for i in range(min(v,len(l1))+1):
    # print(t)
    t = s1[i]+s2[min(len(l2),int((v-i)/2))]
    if ans < t:num,ans=i,t

print(ans)
for i in range(num):print(l1[i][1],end=' ')
for i in range(min(len(l2),int((v-num)/2))):print(l2[i][1],end=' ')

2)另外一个思路是:引入第3个因素:价值密度,不分AB只按密度大小填充。如果刚好填满,结束。否则只可能是填的最后一个是B(B0)导致超出1个体积。此时查找填充队列中的最后一个A(A0),和剩下的密度最大A(A1).

甲)A0+A1>B0:去掉B0,填入A1:相反则去掉A0.结束。

乙)A0不存在A1存在:填入A1.结束。

丙)A0存在A1不存在:比较A0和B0的价值,谁小去掉谁.结束。

丁)A0、A1都不存在:去掉B0.结束。

n,p =map(int,input().split())
a=[0]*n
for i in range(n):
   t,v=map(int,input().split())
   a[i]=(i,t,v)
a.sort(key=lambda x:x[2]/x[1],reverse=True)

ans,index,lst=0,0,[]
last1=(-1,0)
while p>0 and index<n:
   i,t,v=a[index]
   if t==1:last1=(i,v)
   p-=t
   ans+=v
   lst.append(i)
   index+=1
   
if p==-1: #p==-1 and t==2
   now=(i,v)
   while t==2 and index<n:
      i,t,v=a[index]
      index+=1
   if last1[0]>-1 and t==1: #exist 1 in lst and later
      if v+last1[1]<now[1]:#swapcase->pop last1
         ans-=last1[1]
         lst.remove(last1[0])
      else:
         ans=ans-now[1]+v
         lst.remove(now[0])
         lst.append(i)
   elif last1[0]>-1 and t==2: #exist 1 in lst only
      if last1[1]<now[1]:
         ans-=last1[1]
         lst.remove(last1[0])
      else:
         ans-=now[1]
         lst.remove(now[0])
   elif t==1 and last1[0]==-1: #exist 1 in later only
      ans=ans-now[1]+v
      lst.remove(now[0])
      lst.append(i)
   else:
      ans-=now[1]
      lst.remove(now[0])
print(ans)
for i in lst:print(i+1,end=' ')

codeforces 3b之贪心算法的更多相关文章

  1. 贪心算法(Greedy Algorithm)

    参考: 五大常用算法之三:贪心算法 算法系列:贪心算法 贪心算法详解 从零开始学贪心算法 一.基本概念: 所谓贪心算法是指,在对问题求解时,总是做出在当前看来是最好的选择.也就是说,不从整体最优上加以 ...

  2. 算法导论----贪心算法,删除k个数,使剩下的数字最小

    先贴问题: 1个n位正整数a,删去其中的k位,得到一个新的正整数b,设计一个贪心算法,对给定的a和k得到最小的b: 一.我的想法:先看例子:a=5476579228:去掉4位,则位数n=10,k=4, ...

  3. LEETCODE —— Best Time to Buy and Sell Stock II [贪心算法]

    Best Time to Buy and Sell Stock II Say you have an array for which the ith element is the price of a ...

  4. ACM_ICPC hdu-2111(简单贪心算法)

    一道非常简单的贪心算法,但是要注意输入的价值是单位体积的价值,并不是这个物品的总价值!#include <iostream> #include <stdio.h> #inclu ...

  5. 基于贪心算法的几类区间覆盖问题 nyoj 12喷水装置(二) nyoj 14会场安排问题

    1)区间完全覆盖问题 问题描述:给定一个长度为m的区间,再给出n条线段的起点和终点(注意这里是闭区间),求最少使用多少条线段可以将整个区间完全覆盖 样例: 区间长度8,可选的覆盖线段[2,6],[1, ...

  6. 增强学习贪心算法与Softmax算法

    (一) 这个算法是基于一个概率来对探索和利用进行折中:每次尝试时,以概率进行探索,即以均匀概率随机选取一个摇臂,以的概率进行利用,即以这个概率选择当前平均奖赏最高的摇臂(如有多个,则随机选取). 其中 ...

  7. 【九度OJ】题目1434贪心算法

    题目 本题的贪心算法策略需要深入思考一下 看到题目,最初没有理解题目的要求:看尽量多的完整的节目.尽量多是指数量多,自己理解成观看的时间最长.这样想其实简化了这道题. 正确理解题意后,首先想到的想法是 ...

  8. 题目1437:To Fill or Not to Fill:贪心算法解决加油站选择问题(未解决)

    //贪心算法解决加油站选择问题 //# include<iostream> # include<stdio.h> using namespace std; # include& ...

  9. 贪心算法(Greedy Algorithm)之最小生成树 克鲁斯卡尔算法(Kruskal&#39;s algorithm)

    克鲁斯卡尔算法(Kruskal's algorithm)是两个经典的最小生成树算法的较为简单理解的一个.这里面充分体现了贪心算法的精髓.大致的流程能够用一个图来表示.这里的图的选择借用了Wikiped ...

随机推荐

  1. HTML与CSS的一些知识(二)

    续: 5.表单标签<form></form> 用于收集用户信息,统一提交到服务器 一般用input标签收集,再用提交按钮提交:input标签根据type属性值不同有不同的类型: ...

  2. Oh-My-Zsh及主题、插件安装与配置

    切换zsh Manjaro linux默认安装了zsh,其他可能需要先安装 cat /etc/shells #查看本地有哪几种shell chsh -s /bin/zsh #切换到zsh 默认终端启动 ...

  3. [译]RabbitMQ教程C#版 - 路由

    先决条件 本教程假定 RabbitMQ 已经安装,并运行在localhost标准端口(5672).如果你使用不同的主机.端口或证书,则需要调整连接设置. 从哪里获得帮助 如果您在阅读本教程时遇到困难, ...

  4. vue-cli3.0 笔记

      vue-cli 3.0   npm install -g @vue/cli # OR yarn global add @vue/cli ui 界面创建项目 vue ui 命令行创建项目 步骤 vu ...

  5. 微信小程序http连接访问解决方案

    HTTP + 加密 + 认证 + 完整性保护 = HTTPS,小程序考虑到信息安全的问题,选用了更为稳定安全的https 来进行信息传递. HTTPS协议的主要作用可以分为两种:一种是建立一个信息安全 ...

  6. 应对 Visual Stdio 编译时出现错误:常量中有换行符

    笔者最近用 Visual Stdio 时,发现一个问题,在某一次写完语言进行编绎运行时,出现了以下错误: C2001错误:变量中有换行符 C2413错误:语法错误 缺少")"(在& ...

  7. leecode第二百三十八题(除自身以外数组的乘积)

    class Solution { public: vector<int> productExceptSelf(vector<int>& nums) { int len= ...

  8. Lab 11-1

    Analyze the malware found in Lab11-01.exe. Questions and Short Answers What does the malware drop to ...

  9. Codeforces Round #422 (Div. 2)E. Liar sa+st表+dp

    题意:给你两个串s,p,问你把s分开顺序不变,能不能用最多k段合成p. 题解:dp[i][j]表示s到了前i项,用了j段的最多能合成p的前缀是哪里,那么转移就是两种,\(dp[i+1][j]=dp[i ...

  10. line-height:150%与line-height:1.5的区别

    今天看到一篇文章,说的是CSS学习中的瓶颈,我最近也发现自己css很薄弱,写的样式总是有兼容性问题,要写很久,发现了一个问题,我从来没有用过line-height:150和line-height:1. ...