poj 1717==洛谷P1282 多米诺骨牌
| Time Limit: 1000MS | Memory Limit: 65536K | |
| Total Submissions: 6571 | Accepted: 2178 |
Description

The number of dots in the top
line is 6+1+1+1=9 and the number of dots in the bottom line is 1+5+3+2=11. The
gap between the top line and the bottom line is 2. The gap is the absolute value
of difference between two sums.
Each domino can be turned by 180 degrees
keeping its face always upwards.
What is the smallest number of turns
needed to minimise the gap between the top line and the bottom line?
For
the figure above it is sufficient to turn the last domino in the row in order to
decrease the gap to 0. In this case the answer is 1.
Write a program that:
computes the smallest number of turns needed to minimise the gap between the top
line and the bottom line.
Input
<= n <= 1000. This is the number of dominoes laid out on the table.
Each of the next n lines contains two integers a, b separated by a
single space, 0 <= a, b <= 6. The integers a and b written in the line i +
1 of the input file, 1 <= i <= 1000, are the numbers of dots on the i-th
domino in the row, respectively, in the top line and in the bottom one.
Output
the gap between the top line and the bottom line.
Sample Input
4
6 1
1 5
1 3
1 2
Sample Output
1
Source
P1282 多米诺骨牌
题目描述
多米诺骨牌有上下2个方块组成,每个方块中有1~6个点。现有排成行的
上方块中点数之和记为S1,下方块中点数之和记为S2,它们的差为|S1-S2|。例如在图8-1中,S1=6+1+1+1=9,S2=1+5+3+2=11,|S1-S2|=2。每个多米诺骨牌可以旋转180°,使得上下两个方块互换位置。
编程用最少的旋转次数使多米诺骨牌上下2行点数之差达到最小。

对于图中的例子,只要将最后一个多米诺骨牌旋转180°,可使上下2行点数之差为0。
输入输出格式
输入格式:
输入文件的第一行是一个正整数n(1≤n≤1000),表示多米诺骨牌数。接下来的n行表示n个多米诺骨牌的点数。每行有两个用空格隔开的正整数,表示多米诺骨牌上下方块中的点数a和b,且1≤a,b≤6。
输出格式:
输出文件仅一行,包含一个整数。表示求得的最小旋转次数。
输入输出样例
4
6 1
1 5
1 3
1 2
1 风格1:
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
int const N=;
int const inf=0x3f3f3f3f;
int a[N],b[N],n;
int f[N][N**];//表示差值+p为j时的最小次数
int main(){
memset(f,0x3f,sizeof(f));
scanf("%d",&n);
for(int i=;i<=n;i++) scanf("%d%d",a+i,b+i);
int v=n**;
int p=n*;
f[][p]=;
//以下部分是两种不同的区间平移 其实第二种看起来更清晰 而且第一种会出现下标越界的情况 但是不知道为何竟然A了
for(int i=;i<=n;i++){
for(int j=;j<=v;j++){
f[i][j]=min(f[i-][j-(a[i]-b[i])],f[i-][j-(b[i]-a[i])]+);
}
}
for(int i=;i<=n;i++){
for(int j=-p;j<=p;j++){
f[i][j+p]=min(f[i-][j+a[i]-b[i]+p],f[i-][j+b[i]-a[i]+p]+);
}
}
//
for(int i=;i<=p;i++){
if(min(f[n][p+i],f[n][p-i])!=inf){
printf("%d\n",min(f[n][p+i],f[n][p-i]));
return ;
}
}
}
风格2:
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
#define ref(i,x,y)for(register int i=x;i<=y;i++)
#define def(i,x,y)for(register int i=x;i>=y;i--)
#define Q 2000
int a,b,n,nn,w[];
int f[][];
void first(){
scanf("%d",&n);
ref(i,,n) scanf("%d%d",&a,&b),w[i]=a-b;
}
void go(){
nn=*n;
memset(f,,sizeof(f));
f[][w[]+nn]=;
f[][-w[]+nn]=;
ref(i,,n) def(j,*n,){
if(j+w[i]>=&&j+w[i]<=*n)
f[i][j]=min(f[i][j],f[i-][j+w[i]]+);
if(j-w[i]>=&&j-w[i]<=*n)
f[i][j]=min(f[i][j],f[i-][j-w[i]]);
}
if(f[n][*n]<Q) {printf("%d\n",f[n][*n]);return;}
else{
for(int i=nn-,j=nn+;i>=&&j<=*nn;i--,j++){
if(f[n][i]<Q||f[n][j]<Q){
printf("%d\n",min(f[n][i],f[n][j]));
return;
}
}
}
}
int main(){
first();
go();
return ;
}
poj 1717==洛谷P1282 多米诺骨牌的更多相关文章
- 洛谷P1282 多米诺骨牌 (DP)
洛谷P1282 多米诺骨牌 题目描述 多米诺骨牌有上下2个方块组成,每个方块中有1~6个点.现有排成行的 上方块中点数之和记为S1,下方块中点数之和记为S2,它们的差为|S1-S2|.例如在图8-1中 ...
- 洛谷P1282 多米诺骨牌
P1282 多米诺骨牌 题目描述 多米诺骨牌有上下2个方块组成,每个方块中有1~6个点.现有排成行的 上方块中点数之和记为S1,下方块中点数之和记为S2,它们的差为|S1-S2|.例如在图8-1中,S ...
- 【01背包】洛谷P1282多米诺骨牌
题目描述 多米诺骨牌有上下2个方块组成,每个方块中有1~6个点.现有排成行的 上方块中点数之和记为S1,下方块中点数之和记为S2,它们的差为|S1-S2|.例如在图8-1中,S1=6+1+1+1=9, ...
- 洛谷 P1282 多米诺骨牌 ( 线性DP )
题意 : 题目链接 分析 : 一开始这个想法也有想到,但是貌似要开很大数组,就感觉应该不行 遂放弃想其他方法,万万没想到注意到可以滚动优化(其实不优化也可以过) 定义 dp[i][j] 表示 到第 ...
- 洛谷P1282 多米诺骨牌【线性dp】
题目:https://www.luogu.org/problemnew/show/P1282 题意: 给定n个牌,每个牌有一个上点数和下点数.可以通过旋转改变交换上下点数. 问使得上点数之和和下点数之 ...
- 洛谷 [P1282] 多米诺骨牌
这道题是一道背包问题,考虑一个背包, 显然如果我们直接设dp[i]表示前i个使差值最小所需的最少翻转次数,是具有后效性的. 所以我们将直接求最值,改为求某个值是否可行,这种求最值转变为求可行性的思想是 ...
- 洛谷 P1282 多米诺骨牌("01"背包)
传送门 https://www.cnblogs.com/violet-acmer/p/9852294.html 参考资料: [1]:https://blog.csdn.net/Darost/artic ...
- yzoj P2043 & 洛谷 P1282 多米诺骨牌 题解
题意 类似于就是背包. 解析 代码 跟解析有点不一样v[i]价值,w[i]重量,s背包容积,背包转移即可. #include<bits/stdc++.h> using namespace ...
- P1282 多米诺骨牌【dp】
P1282 多米诺骨牌 提交 20.02k 通过 6.30k 时间限制 1.00s 内存限制 125.00MB 题目提供者洛谷 难度提高+/省选- 历史分数100 提交记录 查看题解 标签 查看算 ...
随机推荐
- Mysql 中文中繁杂的字 插入报错的 解决方案
首先 数据库默认编码选用 utf8 连接字符串也相应改成utf8,不能是gb2312
- Unity3D在WebPlayer模式下的异常上报探索
原地址:http://www.cnblogs.com/hisiqi/archive/2013/07/21/3203527.html 我们知道,Unity3D在WebPlayer的发布模式下是沙箱环境中 ...
- Java实现图片裁剪预览功能
在项目中.我们须要做些类似头像上传,图片裁剪的功能,ok看以下文章! 须要插件:jQuery Jcrop 后端代码: package org.csg.upload; import java.awt.R ...
- python抓包截取http记录日志
#!/usr/bin/python import pcap import dpkt import re def main(): pc=pcap.pcap(name="eth1" ...
- Spring Cloud简单入门教程
原文地址:http://www.cnblogs.com/skyblog/p/5127690.html 按照官方的话说:Spring Cloud 为开发者提供了在分布式系统(如配置管理.服务发现.断路器 ...
- Cocos2D-X2.2.3学习笔记10(几何图形)
我们这节来学习几何图形,即怎样使用Cocos2d-x绘制各种图形.已经贝塞尔曲线 我们查看CCNode中有个draw函数,我们须要将绘制的代码所有写在这个函数里面.写在init函数里是画不出线来的, ...
- XX年年终总结---重新飞跃
XX年年终总结---重新飞跃 写之前先解释一下为什么是年终总结,由于在提高班学习,每年结束于暑假:新的一年開始于9月. 肚子里的墨水已经找不到新的词语来形容时间过得快了,一年结束了.还有一年又结束了: ...
- LwIP协议栈(2):网络接口
在LwIP中,物理网络硬件接口结构保存在一个全局链表中,它们通过结构体中的 next 指针连接. struct netif { /// pointer to next in linked list * ...
- atitit.Atitit.检测文本文件的编码 java 与php版 。Net
atitit.Atitit.检测文本文件的编码 java 与php版 .Net 1 检测编码原理 Utf8>>gbk 在此转会gbk>>utf 2 工具检测编码 不能使用l ...
- 美团HD(6)-添加搜索遮罩
DJSelectCityViewController.m /** SearchBar开始编辑 */ - (void)searchBarTextDidBeginEditing:(UISearchBar ...