第三讲数学与简单DP
创始人
2025-05-28 19:29:54
0

文章目录

    • 1.买不到的数目(完全背包👍)
      • 结论👍👍👍
    • 2.蚂蚁感冒(数学)

1.买不到的数目(完全背包👍)

在这里插入图片描述
在这里插入图片描述

思路:其实题意就是给你两个整数,可以随便用,和完全背包给你若干物品的重量,数量有无数个,去凑差不多,很多题目就是有基础的变形转换而来的,需要多灵活变通。

此题目还学到了一个结论:
给定a,b,若d=gcd(a,b) > 1则一定不能凑出最大数
结论:
如果a,b均是正整数且互质,那么由ax+by,x>=0,y>=0不能凑出的最大数是(a-1)(b-1)-1

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;public class Main {static BufferedReader br = new BufferedReader(new InputStreamReader(System.in));static PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));static int N = (int) (1e6 + 10);static boolean[] dp = new boolean[N];static int n = 0,m = 0,ans = 0;public static void main(String[] args) throws Exception{String[] nm = br.readLine().split(" ");n = Integer.parseInt(nm[0]);m = Integer.parseInt(nm[1]);dp[0] = true;for(int i = 1; i <= 1e6; i++) {if(i - n >= 0) {dp[i] |= dp[i - n];}if(i - m >= 0) {dp[i] |= dp[i - m];}}for(int i =(int) 1e6; i >= 1; i--) {if(!dp[i]) {System.out.println(i);break;}}}
}

完全背包的写法:(有两种物品的重量,凑)

#include 
using namespace std;
const int N = 1e6 + 100;
int dp[N];
int n, m;
int a[3];
int main()
{cin >> n >> m;a[1] = n; a[2] = m;dp[0] = 1;for (int j = 1; j <= 2; j ++) {for (int i = a[j]; i <= 1e6; i ++) {dp[i] |= dp[i-a[j]];}}for (int i = 1e6 ; i >= 1; i --) {if (dp[i] == 0)  {cout <<  i;break;}}
}

下面这个题同样的做法:
在这里插入图片描述

结论👍👍👍

如果a,b均是正整数且互质,那么由ax+by,x>=0,y>=0,不能凑出来的最大数是ab-a-b((a-1)*(b-1))

2.蚂蚁感冒(数学)

在这里插入图片描述
在这里插入图片描述
思路:此题还是很简单的,我们可以看出只要分类讨论一下感冒的蚂蚁的方向和位置即可,如果感冒的蚂蚁方向是-的,那么我们需要首先看一下有没有一个位置比他小,然后然后是正的(为什么要这样呢,如果有的话,我们可以通过这个蚂蚁去感染那些方向也是-的蚂蚁,只有至少存在一个+方向的蚂蚁的时候,其他-方向的蚂蚁才可能被敢染),如果敢染的蚂蚁是+的同理。
❗:(1)如果感冒的蚂蚁是负方向的,我们必须先看是否存在比它位置小,且方向是+的,否则即使存在位置比它大的-的,也是无法感染的。
(2)注意细节,多想想各种情况就好啦😀


public class Main {static BufferedReader br = new BufferedReader(new InputStreamReader(System.in));static PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));static int N = (int) (100);static int n = 0,m = 0,ans = 0;static int[] a = new int[N];public static void main(String[] args) throws Exception{n = Integer.parseInt(br.readLine());String[]aa = br.readLine().split(" ");for(int i = 1; i <= n; i++) {a[i] = Integer.parseInt(aa[i - 1]);}int p = a[1];if(p < 0) {for(int i = 1; i <= n; i++) {if(Math.abs(a[i]) < Math.abs(p) && a[i] > 0) {ans++;}}for(int i = 1; i <= n; i++) {if(ans != 0) {if(Math.abs(a[i]) > Math.abs(p) && a[i] < 0) {ans++;}}}}else {for(int i = 1; i <= n; i++) {if(Math.abs(a[i]) > p && a[i] < 0) {ans++;}}for(int i = 1; i <= n; i++) {if(ans != 0) {if(a[i] < p && a[i] > 0) {ans++;}}}}System.out.println(ans + 1);}
}

相关内容

热门资讯

扫房神器2安卓系统,打造洁净家... 你有没有发现,家里的灰尘就像小精灵一样,总是悄悄地在你不注意的时候跳出来?别急,今天我要给你介绍一个...
安卓完整的系统设置,全面掌控手... 亲爱的手机控们,是不是觉得你的安卓手机用久了,功能越来越强大,但设置却越来越复杂?别急,今天就来带你...
电视安卓系统是几代机子,揭秘新... 你有没有想过,家里的电视是不是已经升级到了最新的安卓系统呢?别小看了这个小小的系统升级,它可是能让你...
安卓系统隐私有经常去,系统级防... 你知道吗?在咱们这个数字化时代,手机可是我们生活中不可或缺的好伙伴。但是,你知道吗?这个好伙伴有时候...
安卓10系统断网软件,轻松实现... 你有没有遇到过这种情况?手机突然断网了,明明信号满格,却连不上网,急得你团团转。别急,今天就来给你揭...
安卓可以改什么系统版本,体验全... 你有没有想过,你的安卓手机其实可以像换衣服一样,换一个全新的“系统版本”呢?没错,这就是今天我们要聊...
最好的平板游戏安卓系统,畅享指... 亲爱的游戏迷们,你是否在寻找一款能够让你在安卓平板上畅玩无忧的游戏神器?别急,今天我就要给你揭秘,究...
华为安卓系统卡顿解决,华为安卓... 你是不是也遇到了华为安卓系统卡顿的问题?别急,今天就来给你支几招,让你的华为手机重新焕发活力!一、清...
安卓建议升级鸿蒙系统吗,探讨鸿... 亲爱的安卓用户们,最近是不是被鸿蒙系统的新鲜劲儿给吸引了?是不是在犹豫要不要把你的安卓手机升级成鸿蒙...
安卓如何变苹果系统桌面,桌面系... 你有没有想过,把你的安卓手机变成苹果系统桌面,是不是瞬间高大上了呢?想象那流畅的动画效果,那简洁的界...
windows平板安卓系统升级... 你有没有发现,最近你的Windows平板电脑突然变得有些不一样了?没错,就是那个一直默默陪伴你的小家...
安卓系统扩大运行内存,解锁更大... 你知道吗?在科技飞速发展的今天,手机已经成为了我们生活中不可或缺的好伙伴。而手机中,安卓系统更是以其...
安卓系统怎么改变zenly,探... 你有没有发现,你的安卓手机上的Zenly应用最近好像变得不一样了?没错,安卓系统的大手笔更新,让Ze...
英特尔安卓子系统,引领高效移动... 你有没有想过,手机里的安卓系统竟然也能和电脑上的英特尔处理器完美结合呢?这可不是天方夜谭,而是科技发...
永远会用安卓系统的手机,探索安... 亲爱的手机控们,你是否也有那么一款手机,它陪伴你度过了无数个日夜,成为了你生活中不可或缺的一部分?没...
有哪些安卓手机系统好用,好用系... 你有没有发现,现在手机市场上安卓手机的品牌和型号真是琳琅满目,让人挑花了眼?不过别急,今天我就来给你...
卡片记账安卓系统有吗,便捷财务... 你有没有想过,用手机记账是不是比拿着小本本记录来得方便多了?现在,手机上的应用层出不穷,那么,有没有...
武汉摩尔影城安卓系统APP,便... 你有没有想过,一部手机就能带你走进电影的世界,享受大屏幕带来的震撼?今天,就让我带你详细了解武汉摩尔...
联想刷安卓p系统,畅享智能新体... 你有没有发现,最近联想的安卓P系统刷机热潮可是席卷了整个互联网圈呢!这不,我就迫不及待地来和你聊聊这...
mac从安卓系统改成双系统,双... 你有没有想过,你的Mac电脑从安卓系统改成双系统后,生活会有哪些翻天覆地的变化呢?想象一边是流畅的苹...