多米诺骨牌多米诺骨牌多米诺骨牌

Description

Input

输入文件的第一行是一个正整数n(1≤n≤1000),表示多米诺骨牌数。接下来的n行表示n个多米诺骨牌的点数。每行有两个用空格隔开的正整数,表示多米诺骨牌上下方块中的点数a和b,且1≤a,b≤6。

Output

输出文件仅一行,包含一个整数。表示求得的最小旋转次数。

Sample Input

4

6 1

1 5

1 3

1 2

Sample Output

题目大意:

有n个骨牌,每个骨牌上面和下面都有一个1~6的数,每个骨牌可以上下翻转,使上下数字反转,最少翻几次可以使上面数的总和与下面数的总和的差最少

解题思路:

用一个二维数组f[i][j]来表示前i个骨牌上数减下数(上数:上面的数加在一起,下数:下面的数加在一起)为j时翻转的最少次数,每一个骨牌不翻时为-上面的数+下面的数(因为递推要倒着推),翻时为+上面的数-下面的数,然后递推出结果

动态转移方程:

f[i][j]=min{f[i−1][j−a[i]+b[i]]f[i−1][j+a[i]−b[i]]+1f[i][j]=min\left\{\begin{matrix}f[i-1][j-a[i]+b[i]]\\ f[i-1][j+a[i]-b[i]]+1\end{matrix}\right.f[i][j]=min{f[i−1][j−a[i]+b[i]]f[i−1][j+a[i]−b[i]]+1​

第一次AC的代码:

#include<cstdio>
#include<iostream>
#include<cstring>
#define M 6000//设置上限
using namespace std;
int n,k,a[1002],b[1001],f[1001][12010];
int main()
{memset(f,127/3,sizeof(f));//用min时要先赋一个较大的值scanf("%d",&n);f[0][M]=0;//初值,从0开始,因为有负数,所以从M开始,上限是12000(6000),下限是0(-6000)for (int i=1;i<=n;i++)scanf("%d%d",&a[i],&b[i]);for (int i=1;i<=n;i++)for (int j=1;j<=M*2;j++)//正负数都要f[i][j]=min(f[i-1][j-a[i]+b[i]],f[i-1][j+a[i]-b[i]]+1);//前面的是不翻,后面的是翻k=0;//从0开始while ((f[n][M+k]==f[0][1])&&(f[n][M-k]==f[0][1])) k++;//f[0][1]为一开始的值,有变化时说明可以翻成差值为kprintf("%d",min(f[n][M+k],f[n][M-k]));//输出最小的
}

优化后的代码:

#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
int n,M,k,a[1002],b[1001],f[1001][12005];
int main()
{memset(f,127/3,sizeof(f));scanf("%d",&n);M=n*6;//变化主要有M,因为大于n*6的都没有用,所以这样可以省时间f[0][M]=0;for (int i=1;i<=n;i++){scanf("%d%d",&a[i],&b[i]);//塞在一起for (int j=M-i*6;j<=M+i*6;j++)//第一次的范围是-6~6,第二次是-12~12,从M开始,当i加一时,上下的限制各加一,可以省很多时间f[i][j]=min(f[i-1][j-a[i]+b[i]],f[i-1][j+a[i]-b[i]]+1);//动态转移方程}k=0;//从0开始while ((f[n][M+k]==f[0][1])&&(f[n][M-k]==f[0][1])) k++;//f[0][1]为一开始的值,有变化时说明可以翻成差值为kprintf("%d",min(f[n][M+k],f[n][M-k]));//输出最小的
}

【动态规划】 多米诺骨牌 (ssl 1632/luogu 1282)相关推荐

  1. 【动态规划】洛谷 P1282 多米诺骨牌

    [动态规划]洛谷 P1282 多米诺骨牌 时间限制: 1 Sec  内存限制: 128 MB 题目描述 多米诺骨牌有上下2个方块组成,每个方块中有1~6个点.现有排成行的 上方块中点数之和记为S1,下 ...

  2. P1282-多米诺骨牌【dp,背包】

    正题 评测记录:https://www.luogu.org/recordnew/lists?uid=52918&pid=P1282 题目大意 n个多米诺骨牌,上下值不相同,可以交换一个多米诺上 ...

  3. C++ P1282 多米诺骨牌

    题目描述 多米诺骨牌有上下2个方块组成,每个方块中有1~6个点.现有排成行的 上方块中点数之和记为S1,下方块中点数之和记为S2,它们的差为|S1-S2|.例如在图8-1中,S1=6+1+1+1=9, ...

  4. 多米诺骨牌——变形版0,1背包问题

    多米诺骨牌--变形版0,1背包问题 1.题目描述 2.问题分析 3.算法源码 1.题目描述 多米诺骨牌有上下2个方块组成,每个方块中有1~6个点.现有排成行的上方块中点数之和记为S1,下方块中点数之和 ...

  5. Blender多米诺骨牌动画学习教程 The Impossible Domino Run in Blender

    流派:电子学习| MP4 |视频:h264,1280×720 |音频:AAC,48.0 KHz 语言:英语+中英文字幕(根据原英文字幕机译更准确)|大小:8.53 GB 含课程文件 |时长:8h 20 ...

  6. S6 edge+的多米诺骨牌效应:大屏的趋势

    日前,为庆祝三星S6 edge+国行版的顺利发售,三星盖乐世社区的一些粉丝自发组织了三星疯狂"盖星人"第一期活动--活动现场除了可以对S6 edge+进行全方面体验之外,还将演示著 ...

  7. P1282 多米诺骨牌 (差值DP+背包)

    题目描述 多米诺骨牌有上下2个方块组成,每个方块中有1~6个点.现有排成行的 上方块中点数之和记为S1,下方块中点数之和记为S2,它们的差为|S1-S2|.例如在图8-1中,S1=6+1+1+1=9, ...

  8. 【01背包】洛谷P1282多米诺骨牌

    题目描述 多米诺骨牌有上下2个方块组成,每个方块中有1~6个点.现有排成行的 上方块中点数之和记为S1,下方块中点数之和记为S2,它们的差为|S1-S2|.例如在图8-1中,S1=6+1+1+1=9, ...

  9. 多米诺骨牌v.1MEL语言

    // //  //Script Name:多米诺骨牌v.1 //Author:疯狂小猪  //Last Updated: 2011.10.5 //Email:wzybwj@163.com //  // ...

最新文章

  1. Android manifest属性总结
  2. Altium Designer 18 怎么导出CAD文件
  3. 微信开发学习日记(二):3个案例
  4. 公有云网络服务需要考虑的关键点
  5. oracle数据库主主复制
  6. It is worth noting that among the four
  7. 190511每日一句
  8. 计算机基础考试题库(含答案)
  9. C/C++项目源码——数字雨DigitalRain
  10. java计算机毕业设计高校多媒体设备报修管理系统源码+mysql数据库+系统+lw文档+部署
  11. idea出现的怪异现象
  12. 苹果系统版本依次顺序_苹果手机顺序
  13. AutoCAD Electrical 2020 安装后无激活界面
  14. mysql错误1786_mysql错误处理之ERROR 1786 (HY000)
  15. Day.js 一个轻量级的 JavaScript 时间日期处理库
  16. 简单的图片数字时钟js代码
  17. vue的PC端和移动端分辨率适配
  18. Whale帷幄 - 智慧化门店 智慧化运营
  19. Java JVM 动态方法调用之方法句柄 MethodHandle
  20. bzoj 2299(裴蜀定理)

热门文章

  1. java 并发 面试题_阿里面试官总结10个经典技术题:Java多线程与并发面试题
  2. python 进程池_python进程池
  3. python开发一个自己的技术网站_手把手教你写网站:Python WEB开发技术实战
  4. 后端学习 - SpringBoot
  5. 计算机网络:如何传输一条数据(详解)
  6. 高等数学上-赵立军-北京大学出版社-题解-练习2.5
  7. AcWing 523. 组合数问题
  8. 01背包+概率问题 计蒜客 offer
  9. python中类变量的访问方式_在Python中,如何访问类方法中的“静态”类变量
  10. C语言---二进制和文本文件的备份