POJ 1208 模拟
2017-08-28 15:07:16
writer:pprp
好开心,这道题本来在集训的时候做了很长很长时间,但是还是没有做出来,但是这次的话,只花了两个小时就做出来了
好开心,这次采用的是仔细分析需要的函数,写一个函数就将这个函数进行测试,所以效率比较高
这次竟然提交了一次直接AC了,hhhh
我想总结一下这种做题感觉,一直认为自己实现功能的能力比较弱,虽然这是事实,但是没有想象中那么弱,其实还是可以实现很大一部分的内容
之后只要方法对了,然后可以坚持下去,那我就很大几率成功,昨天看视频的时候看到一个很厉害的人他说他身边有的高中同学在大学期间,只用了一年
时间,就将全国金牌拿到手了,并且那个人并不是很聪明,但是他十分努力。所以说我还是有希望的,经过长时间的训练和锻炼是可以达到很高的提升的;
以后做题还是要坚持1、计时 2、审题认真仔细,找到容易忽略的地方,以及特殊情况 3、模块化编程,边编边测试
代码以及详细讲解如下:
/*
@theme:poj 1208
@writer:pprp
@start:11:00-12:00
@end:14:41-13:06
@declare:写一个恶心的模拟题目,
经过抽象,得到两个操作,模拟样例的操作的时候,
可以看出几个特殊情况,如果将a和a上的箱子一起放到b箱上,那么如果b就是a上的箱子,那么不进行操作
注意这个是面向箱子的不是面向位置的
而且发现有两个函数需要构造出来
1、查找函数Find,找到某个箱子的位置,横纵坐标
2、进行输出操作Out,这个还有利于检查
@date:2017/8/28
*/ #include <iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <vector>
#include <queue>
#include <cstring>
#define tag cout << " *** " << endl using namespace std;
int n; deque<int> dq[];
bool Find(deque<int> dq[], int key,int&x, int&y); //操作1:将某箱子上边所有的箱子放回原位
//@param:x, x是箱子x
//test successfully
void resend(int a)
{
int x, y;
Find(dq,a,x,y);
for(int i = (int)dq[x].size()- ; i > y ; i--)
{
int tmp = dq[x].back();
dq[tmp].push_back(tmp);
dq[x].pop_back();
}
return;
} //操作2:将某个箱子和箱子以上的箱子都移动到指定箱子的最上方--ok?
//a到b的上方
void transe(int a, int b)
{
int ax, ay, bx, by;
Find(dq,a,ax, ay);
Find(dq,b,bx, by);
//如果将a和a上的箱子一起放到b箱上,那么如果b就是a上的箱子,那么不进行操作
if(ax == bx)
return; int ak[];
int len = dq[ax].size() - ay ;
for(int i = ; i < len ; i++)
{
ak[i] = dq[ax].back();
dq[ax].pop_back();
} for(int i = len - ; i >= ; i--)
{
dq[bx].push_back(ak[i]);
}
return;
} //操作3:输出操作 -- ok
void Out()
{
for(int i = ; i < n ; i++)
{
cout << i << ": " ;
for(int j = ; j < (int)dq[i].size(); j++)
{
cout << dq[i][j] << " ";
}
cout << endl;
}
} //操作4:查找操作 -- ok
bool Find(deque<int> dq[], int key,int&x, int&y)
{
for(int i = ; i < n ; i++)
{
for(int j = ; j < (int)dq[i].size(); j++)
{
if(key == dq[i][j])
{
x = i;
y = j;
return true;
}
}
}
return false;
}
//操作5:初始化 -- ok
void init()
{
for(int i = ; i < n ; i++)
{
dq[i].push_back(i);
}
return ;
} int main()
{
cin >> n;
init(); // Out();
// dq[8].pop_back();
// dq[1].push_back(8);
// dq[7].pop_back();
// dq[1].push_back(7);
// dq[3].pop_back();
// dq[4].push_back(3);
// dq[5].pop_back();
// dq[4].push_back(5);
// Out(); char line[];
char ch1[],ch2[];
int a = , b = ; // while(cin >> a >> b)
// {
// transe(a,b);
// Out();
// }
while(gets(line))
{
if(strcmp(line,"quit") == )
break;
sscanf(line,"%s %d %s %d",ch1,&a,ch2,&b);
if(strcmp(ch1,"move") == )
{
if(strcmp(ch2,"over") == )//move a over b
{
resend(a);
transe(a,b);
}
else //move a onto b
{
resend(a);
resend(b);
transe(a,b);
}
}
else
{
if(strcmp(ch2,"over") == ) //pile a over b
{
transe(a,b);
}
else //pile a onto b
{
resend(b);
transe(a,b);
}
}
}
Out();
return ;
}
POJ 1208 模拟的更多相关文章
- uva 101 POJ 1208 The Blocks Problem 木块问题 vector模拟
挺水的模拟题,刚开始题目看错了,poj竟然过了...无奈.uva果断wa了 搞清题目意思后改了一下,过了uva. 题目要求模拟木块移动: 有n(0<n<25)快block,有5种操作: m ...
- POJ 1016 模拟字符串
Numbers That Count Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 20396 Accepted: 68 ...
- POJ 1208 The Blocks Problem --vector
http://poj.org/problem?id=1208 晚点仔细看 https://blog.csdn.net/yxz8102/article/details/53098575 #include ...
- POJ 1208 The Blocks Problem
The Blocks Problem Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 5397 Accepted: 231 ...
- POJ - 3087 模拟 [kuangbin带你飞]专题一
模拟洗牌的过程,合并两堆拍的方式:使先取s2,再取s1:分离成两堆的方式:下面C张放到s1,上面C张到s2.当前牌型与第一次相同时,说明不能搜索到答案. AC代码 #include<cstdio ...
- Shuffle'm Up POJ - 3087(模拟)
Shuffle'm Up Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 15249 Accepted: 6962 Des ...
- poj 1379 模拟退火法
/* 模拟退火法: 找到一些随机点,从这些点出发,随机的方向坐标向外搜索: 最后找到这些随机点的最大值: 坑://if(xx>-eps&&xx<x+eps&& ...
- POJ 1471 模拟?
题意:求最大无坏点三角形 思路: 模拟? (为什么我模拟过了...) 有人用 DP,有人用 搜索... // by SiriusRen #include <cstdio> #include ...
- POJ 1951 模拟
思路: 坑爹模拟毁我一生 给两组数据: 输入: YOURE TRAVELING THROUGH ANOTHER DIMENSION A DIMENSION NOT OF SIGHT. 输出: YR T ...
随机推荐
- 剑指Offer——树的子结构
题目描述: 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) 分析: 先匹配到A的某个结点和B的根相同,然后往下继续匹配.不匹配则递归匹配左右子树. 代码: ...
- 如何在 windows 配置 libtorch c++ 前端库?
如何在 windows 配置 libtorch c++ 前端库? 下载 pytorch 已经编译好的库: 此库不带 gpu,主要方便演示.支持 win7 win10 系统. 下载地址:https:// ...
- python中lambda使用
一.lambda函数 1.lambda函数基础: lambda函数也叫匿名函数,即,函数没有具体的名称,而用def创建的方法是有名称的.如下: """命名的foo函数&q ...
- KVm中EPT逆向映射机制分析
2017-05-30 前几天简要分析了linux remap机制,虽然还有些许瑕疵,但总算大致分析的比较清楚.今天分析下EPT下的逆向映射机制.EPT具体的工作流程可参考前面博文,本文对于EPT以及其 ...
- Linux文件操作相关命令
1.创建文件夹: [root@izuf6ih01h8fzeziddwkfdz sm]# mkdir a 创建一个名为a的文件夹 2.创建文件: [root@izuf6ih01h8fzeziddwkfd ...
- 浅谈pipreqs组件(自动生成需要导入的模块信息)
简介 pipreqs的作用 一起开发项目的时候总是要搭建环境和部署环境的,这个时候必须得有个python第三方包的list,一般都叫做requirements.txt. 如果一个项目使用时virtua ...
- Linux chmod命令
chmod用于管理文件或目录的权限,文件或目录权限的控制分别以读取(r).写入(w).执行(x)3种 可读可写可执行,抽象的用二进制来表示 1 代表拥有该权限,0 代表没有该权限,这样我们就可以看到 ...
- js-jquery-002-条形码-一维码
一.使用 官方地址:http://barcode-coder.com/en/barcode-jquery-plugin-201.html 1.js引用 <script type="te ...
- PKU 1379 Run Away(模拟退火算法)
题目大意:原题链接 给出指定的区域,以及平面内的点集,求出一个该区域内一个点的坐标到点集中所有点的最小距离最大. 解题思路:一开始想到用随机化算法解决,但是不知道如何实现.最后看了题解才知道原来是要用 ...
- vue生命周期探究(二)
vue生命周期探究(二) 转载自:https://segmentfault.com/a/1190000008923105 上一章我们介绍了vue的组件生命周期和路由勾子,这一章,让我们来看看在vue- ...