题意:对于一行按照顺序排列盒子数字与位置都为 1,2,3,4....n

执行四种操作

c = 1    x 放到 y 的左边

c =2     x 放到 y 的右边

c =3   交换 x, y

c =4   颠倒链

最后求出奇数位置的数的总和

题解:直接维护无论如何每次每次都需要维护一段区间的位置,因此不去看位置、只需要知道每个盒子左边是哪个盒子右边是哪个盒子

   这样就直接使用双向链表维护,接着颠倒时注意只是标记就好

   最后注意几个细节:

    首先颠倒后1与2的交换需要互换;

    维护链表时可以提取出一个函数,每次都只需要多次使用这个函数;

    c等于1,2,3时x与y的位置相邻时会出现很大的问题

#include<set>
#include<map>
#include<queue>
#include<stack>
#include<cmath>
#include<vector>
#include<string>
#include<cstdio>
#include<cstring>
#include<iomanip>
#include<stdlib.h>
#include<iostream>
#include<algorithm>
using namespace std;
#define eps 1E-8
/*注意可能会有输出-0.000*/
#define sgn(x) (x<-eps? -1 :x<eps? 0:1)//x为两个浮点数差的比较,注意返回整型
#define cvs(x) (x > 0.0 ? x+eps : x-eps)//浮点数转化
#define zero(x) (((x)>0?(x):-(x))<eps)//判断是否等于0
#define mul(a,b) (a<<b)
#define dir(a,b) (a>>b)
typedef long long ll;
typedef unsigned long long ull;
const int Inf=<<;
const ll INF=1LL<<;
const double Pi=acos(-1.0);
const int Mod=1e9+;
const int Max=;
struct node
{
int left,right;
} ball[Max];//**表示i这个数字左右两边的数字**
void initPosition(int n)//双向链表初始化
{
for(int i=; i<=n; ++i)
{
ball[i].left=i-;
ball[i].right=(i+)%(n+);
}
}
void link(int l,int r)//左右相互连接
{
ball[l].right=r;
ball[r].left=l;
}
inline void Solve(int type,int &mark)
{
if(type==)
{
mark=(mark^);
return;
}
if(type!=&&!mark)
type=-type;//注意反转后只需交换type的1与2就好
int x,y;
scanf("%d %d",&x,&y);
int Lx=ball[x].left;
int Rx=ball[x].right;
int Ly=ball[y].left;
int Ry=ball[y].right;
if(type==&&Rx==y||type==&&Lx==y)
return;
if(type==)//通过下标找到x、y,将x放在y的左边
{
link(Lx,Rx);//**找到6个交换的规律**
link(Ly,x);
link(x,y);
}
else if(type==)
{
link(Lx,Rx);
link(x,Ry);
link(y,x);
}
else if(type==)
{
if(Rx==y)//注意
{
link(Lx,y);
link(y,x);
link(x,Ry);
}
else if(Lx==y){
link(y,Rx);
link(Ly,x);
link(x,y);
}
else
{
link(y,Rx);
link(Ly,x);
link(Lx,y);
link(x,Ry);
}
}
}
ll Print(int n,int mark)
{
ll res=0LL;
int start=;
for(int i=; i<=n; ++i)
{
if(ball[i].left==)
{
start=i;
break;
}
}
int now=start;
int coun=;
while(now)
{
res+=now;
now=ball[now].right;
if(now)
now=ball[now].right;
}
if(!(n&)&&!mark)
res=(ll)n*(n+)/-res;
return res;
}
int main()
{
int n,m;
int coun=;
while(~scanf("%d %d",&n,&m))
{
initPosition(n);
int mark=;//标记是否反转
while(m--)
{
int type;
scanf("%d",&type);
Solve(type,mark);
}
printf("Case %d: %lld\n",++coun,Print(n,mark));
}
return ;
}

UVA 12657 Boxes in a Line(双向链表+小技巧)的更多相关文章

  1. UVA 12657 Boxes in a Line 双向链表

    题目连接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=47066 利用链表换位置时间复杂度为1的优越性,同时也考虑到使用实际 ...

  2. UVa 12657 Boxes in a Line(应用双链表)

    Boxes in a Line You have n boxes in a line on the table numbered 1 . . . n from left to right. Your ...

  3. UVA 12657 Boxes in a Line

    双向链表 注意:如果算法是最后处理翻转情况时,注意指令4翻转后1,2两个指令也要翻转处理: 指令3 中交换盒子要注意两个盒子相邻的情况 #include <iostream> #inclu ...

  4. UVa 12657 Boxes in a Line(数组模拟双链表)

    题目链接 /* 问题 将一排盒子经过一系列的操作后,计算并输出奇数位置上的盒子标号之和 解题思路 由于数据范围很大,直接数组模拟会超时,所以采用数组模拟的链表,left[i]和right[i]分别表示 ...

  5. 2019 SCUT SE 新生训练第四波 L - Boxes in a Line——双向链表

    先上一波题目 https://vjudge.net/contest/338760#problem/L 这道题我们维护一个双向链表 操作1 2 3 都是双向链表的基本操作 4操作考虑到手动将链表反转时间 ...

  6. uva-12657 - Boxes in a Line(双向链表)

    12657 - Boxes in a Line You have n boxes in a line on the table numbered 1 . . . n from left to righ ...

  7. Boxes in a Line UVA - 12657

      You have n boxes in a line on the table numbered 1...n from left to right. Your task is to simulat ...

  8. Boxes in a Line

    Boxes in a Line You have n boxes in a line on the table numbered 1 . . . n from left to right. Your ...

  9. Boxes in a Line(移动盒子)

      You have n boxes in a line on the table numbered 1 . . . n from left to right. Your task is to sim ...

随机推荐

  1. llvm,gcc

    GCC,LLVM,Clang编译器对比   在XCode中,我们经常会看到这些编译选项(如下图),有些人可能会有些茫然,本文将对GCC4.2.LLVM GCC 4.2.LLVM compliler 2 ...

  2. python的@classmethod和@staticmethod

    本文是对StackOverflow上的一篇高赞回答的不完全翻译,原文链接:meaning-of-classmethod-and-staticmethod-for-beginner Python面向对象 ...

  3. 前端开发 - JQuery - 中

    十四.jquery属性操作 attr prop <!DOCTYPE html> <html lang="en"> <head> <meta ...

  4. 【Servlet】把文件写到Respond输出流里面供用户下载

    本文区分于<[Jsp]把Java写到Respond输出流里面供用户下载>(点击打开链接)把原本该打印到控制台的内容,直接打印到一个文本文件txt中给用户下载. 实际上是<[Strut ...

  5. Push h.264 rawdata to rtmp server

    Push h.264 rawdata to rtmp server /* The MIT License (MIT) Copyright (c) 2013-2015 SRS(ossrs) Permis ...

  6. mysql 主从同步-读写分离

    主从同步与读写分离测试 一.  实验环境(主从同步) Master                   centos 7.3              192.168.138.13 Slave     ...

  7. .globl分析

    Uboot中常看到.globl .globl _start _start: b reset .align .globl _TEXT_BASE _TEXT_BASE: .globl _start  /* ...

  8. POJ1836:Alignment(LIS的应用)

    题目链接:http://poj.org/problem?id=1836 题目要求: 给你n个数,判断最少去掉多少个数,从中间往左是递减的序列,往右是递增的序列 需注意的是中间可能为两个相同的值,如 1 ...

  9. SQL Server 2008 添加登录账户并配置权限

    首先打开数据库,并以windows身份验证模式进入数据库. 然后在左侧的[对象资源管理器中]展开[安全性]节点,鼠标右键点击节点中的[登录名],在弹出的菜单中单击[新建登录名],弹出一个对话框. 1. ...

  10. python 中元祖tuple的使用

    Python的元组与列表类似,不同之处在于元组的元素不能修改. 元组使用小括号,列表使用方括号. 元组创建很简单,只需要在括号中添加元素,并使用逗号隔开即可. eg,  tup1 = (1, 2, 3 ...