POJ 1742 Coins ( 单调队列解法 )「建议收藏」

POJ 1742 Coins ( 单调队列解法 )

大家好,又见面了,我是全栈君。

博客

再加上这题体积与价值相等那么就更好做了。仅仅有 j %v[ i ] 余数同样的才干够同一时候处理(j 指的是某个体积的值),在计算某个数的时候,仅仅要计算前面的同样的余数中(在个数限制内)是否有 true(有放满的) 就能够了。

代码:

#include<iostream>
#include<sstream>
#include<map>
#include<cmath>
#include<fstream>
#include<queue>
#include<vector>
#include<sstream>
#include<cstring>
#include<cstdio>
#include<stack>
#include<bitset>
#include<ctime>
#include<string>
#include<cctype>
#include<iomanip>
#include<algorithm>
using namespace std  ;
#define INT long long int
#define L(x)  (x * 2)
#define R(x)  (x * 2 + 1)
const int INF = 0x3f3f3f3f ;
const double esp = 0.0000000001 ;
const double PI = acos(-1.0) ;
const int mod = 1000000007 ;
const int MY = (1<<5) + 5 ;
const int MX = 100010 + 5 ;
int n ,W ,ans ;
int v[MX] ,num[MX] ;
bool deq[MX] ,dp[MX] ;
void input()
{
    memset(dp ,false ,sizeof(dp)) ;
    for(int i = 1 ;i <= n ; ++i)
        scanf("%d" ,&v[i]) ;
    for(int i = 1 ;i <= n ; ++i)
        scanf("%d" ,&num[i]) ;
}
void DP(int v ,int num)
{
    if(!num || !v)  return ;
    if(num == 1) // 01 背包
    {
        for(int i = W ;i >= v ; --i)
           if(!dp[i] && dp[i-v])
               dp[i] = true ,ans++ ;
    }
    else if(num * v >= W) // 全然背包
    {
        for(int i = v ;i <= W ; ++i)
          if(!dp[i] && dp[i-v])
              dp[i] = true ,ans++ ;
    }
    else
    {
        num = min(num ,W/v) ;
        for(int a = 0 ;a < v ; ++a)  // 同样余数一块处理
        {
            int front =0 ,end = 0 ,sum = 0 ;
            for(int j = a ;j <= W ; j += v)
            {
                if(end - front-1 == num)  // 去除过时元素 ,由于最多选择num[i] 个
                    sum -= deq[front++] ;
                deq[end++] = dp[j] ;  // 存入
                sum += dp[j] ;
                if(!dp[j] && sum)
                    dp[j] = true ,ans++ ;

            }
        }
    }
}
int main()
{
    //freopen("input.txt" ,"r" ,stdin) ;
    while(scanf("%d%d" ,&n ,&W) ,n+W)
    {
        input() ;
        dp[0] = true ;
        ans = 0 ;
        for(int i = 1 ;i <= n ; ++i)
             DP(v[i] ,num[i]) ;
        printf("%d\n" ,ans) ;
    }
    return 0 ;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116515.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python爬虫总是爬不到数据,你需要解决反爬虫了

    python爬虫总是爬不到数据,你需要解决反爬虫了

    2021年11月10日
    98
  • 单目摄像机标定程序「建议收藏」

    单目摄像机标定程序「建议收藏」我自己写了一个摄像机标定程序,核心算法参照learningopencv,但是那个程序要从命令行预先输入参数,且标定图片要预先准备好,我觉得不太好,我就自己写了一个,跟大家分享下。若有纰漏,希望大家指正!#include”stdafx.h”#include”cv.h”#include”highgui.h”#include#includeusingname

    2025年6月13日
    2
  • C语言三目运算符_c语言两个逗号表达式

    C语言三目运算符_c语言两个逗号表达式1、三目运算符三目运算符也叫条件运算符、三元运算符,是由一个问号和一个冒号组成。语法:表达式1?表达式2:表达式3;语义:先执行表达式1,如果表达式1的结果如果为真,那么执行表达式2,并且这个整体的运算式的结果是表达式2的结果;如果表达式1的结果如果为假,执行表达式3,运算式的结果是表达式3的结果。inta,b,c;a=7;b=6;c=(a>b)?a…

    2022年10月4日
    1
  • 展频技术是如何搞定时钟信号的辐射的呢_辐射电磁波的频率

    展频技术是如何搞定时钟信号的辐射的呢_辐射电磁波的频率先前我们说了说:为什么时钟信号比数据信号更容易引起辐射超标?为什么时钟信号比数据信号更容易引起辐射超标?并且做了试验,如果认真看过的话,就会明白,周期性的信号是窄带频谱,特定的频率的幅值会很高,这对认证测试来说非常的不利。而一般时钟信号都是周期信号,这在电路中是少不了的。有没有什么办法,改造下时钟的频谱,同时又不影响功能呢?答案是有的,那就是展频技术。展频技术的应用展频技术经常用于解决辐射问题,比如我们前面说的音频功放,需要接LC滤波器。就有的厂家通过展频技术,推出不需要LC滤波器.

    2025年7月25日
    1
  • Android视图与布局整理

    Android视图与布局整理

    2021年9月30日
    31
  • java反射之Method的invoke方法实现[通俗易懂]

    java反射之Method的invoke方法实现[通俗易懂]在框架中经常会会用到method.invoke()方法,用来执行某个的对象的目标方法。以前写代码用到反射时,总是获取先获取Method,然后传入对应的Class实例对象执行方法。然而前段时间研究invoke方法时,发现invoke方法居然包含多态的特性,这是以前没有考虑过的一个问题。那么Method.invoke()方法的执行过程是怎么实现的?它的多态又是如何实现的呢?本文将从java和JVM…

    2022年6月14日
    34

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号