大学生程序代写

http://acm.nyist.net/JudgeOnline/problem.php?pid=511

这道题很容易想到要构建一个循环链表来确定每个球的相对位置,就是操作比较繁琐,考虑情况较多。

首先要创建节点Node,每个节点都有一个初始顺序order,指向左边的Node*指针left,何指向右边的Node*指针right。

  1. struct Node
  2. {
  3. int order;
  4. Node *left,*right;
  5. }node[N];

然后给每个小球附上顺序,并建立和左右的联系。

  1. void build(int n)
  2. {
  3. int i,order=1;
  4. for(i=1;i<n;i++)
  5. {
  6. node[i].order=i;
  7. node[i].right=&node[i+1];
  8. node[i+1].left=&node[i];
  9. }
  10. node[1].left=&node[n];
  11. node[n].right=&node[1];
  12. node[n].order=n;
  13. }  
     

    然后就是A、B操作,下边叙述一下A操作(将x放在y左边)的实现方法:

1.将x左边节点的right指针指向x的右边节点

2.将x右边节点的left指针指向x的左边节点

3.将x的right指向y节点

4.将x的left指向y左边的节点

5.将y左边节点的right指向x节点

6.将y的left指向x节点

实现代码:

  1. void A(int x,int y)
  2. {
  3. Node *p=&node[x],*q=&node[y];
  4. p->left->right=p->right;
  5. p->right->left=p->left;
  6. p->left=q->left;
  7. p->right=q;
  8. q->left->right=p;
  9. q->left=p;
  10. }  
     

    由于交换位置仅改变节点的左右指针,并没有改变数组的下标(下标其实与order相同),所以查找球号时直接用下标索引。

同理可知操作B。

完整代码如下:

  1. #include<stdio.h>
  2. const int N=10005;
  3. struct Node
  4. {
  5. int order;
  6. Node *left,*right;
  7. }node[N];
  8. void build(int n)
  9. {
  10. int i,order=1;
  11. for(i=1;i<n;i++)
  12. {
  13. node[i].order=i;
  14. node[i].right=&node[i+1];
  15. node[i+1].left=&node[i];
  16. }
  17. node[1].left=&node[n];
  18. node[n].right=&node[1];
  19. node[n].order=n;
  20. }
  21. void A(int x,int y)
  22. {
  23. Node *p=&node[x],*q=&node[y];
  24. p->left->right=p->right;
  25. p->right->left=p->left;
  26. p->left=q->left;
  27. p->right=q;
  28. q->left->right=p;
  29. q->left=p;
  30. }
  31. void B(int x,int y)
  32. {
  33. Node *p=&node[x],*q=&node[y];
  34. p->left->right=p->right;
  35. p->right->left=p->left;
  36. p->right=q->right;
  37. q->right->left=p;
  38. p->left=q;
  39. q->right=p;
  40. }
  41. int main()
  42. {
  43. int ncase,n,m,i;
  44. char cmd;
  45. int x,y;
  46. scanf("%d",&ncase);
  47. while(ncase--)
  48. {
  49. scanf("%d%d",&n,&m);
  50. build(n);
  51. while(m--)
  52. {
  53. scanf("%*c%c%d%d",&cmd,&x,&y);
  54. switch(cmd)
  55. {
  56. case 'A':
  57. A(x,y);break;
  58. case 'B':
  59. B(x,y);break;
  60. case 'Q':
  61. printf("%d\n",x?node[y].right->order:node[y].left->order);break;
  62. }
  63. }
  64. }
  65. return 0;
  66. }

其实此题还可以不用链表,对比了一下,时间相差不大,相比而言非链表法更不容易出错。

思路基本一样,直接给出代码:

  1. #include<cstdio>
  2. const int N=10005;
  3. struct xyz
  4. {
  5. int prv,nxt;
  6. }a[N];
  7. void build(int n)
  8. {
  9. int i;
  10. for(i=1;i<=n;i++)
  11. {
  12. a[i].prv=i-1;
  13. a[i].nxt=i+1;
  14. }
  15. a[1].prv=n;
  16. a[n].nxt=1;
  17. }
  18. void A(int x,int y)
  19. {
  20. a[a[x].prv].nxt=a[x].nxt;
  21. a[a[x].nxt].prv=a[x].prv;
  22. a[x].nxt=y;
  23. a[x].prv=a[y].prv;
  24. a[a[y].prv].nxt=x;
  25. a[y].prv=x;
  26. }
  27. void B(int x,int y)
  28. {
  29. a[a[x].prv].nxt=a[x].nxt;
  30. a[a[x].nxt].prv=a[x].prv;
  31. a[x].nxt=a[y].nxt;
  32. a[x].prv=y;
  33. a[a[y].nxt].prv=x;
  34. a[y].nxt=x;
  35. }
  36. int main()
  37. {
  38. int ncase,n,m,i;
  39. char cmd;
  40. int x,y;
  41. scanf("%d",&ncase);
  42. while(ncase--)
  43. {
  44. scanf("%d%d",&n,&m);
  45. build(n);
  46. while(m--)
  47. {
  48. scanf("%*c%c%d%d",&cmd,&x,&y);
  49. switch(cmd)
  50. {
  51. case 'A':
  52. A(x,y);break;
  53. case 'B':
  54. B(x,y);break;
  55. case 'Q':
  56. printf("%d\n",x?a[y].nxt:a[y].prv);break;
  57. }
  58. }
  59. }
  60. return 0;
  61. }
作者:chao1983210400 发表于2013-7-23 23:52:07 原文链接
阅读:12 评论:0 查看评论

[转]NYOJ-511-移动小球的更多相关文章

  1. leetcode排列,求第k个排列

    stl 中的下一个排列在写一遍忘了 写个1个多小时,使用递归写的,错误就在我使用一个list保存当前剩下的数,然后利用k/(n-1)!的阶乘就是删除的数字,但进过观察, 比如 list={1,2,3} ...

  2. NYOJ 1007

    在博客NYOJ 998 中已经写过计算欧拉函数的三种方法,这里不再赘述. 本题也是对欧拉函数的应用的考查,不过考查了另外一个数论基本定理:如何用欧拉函数求小于n且与n互质所有的正整数的和. 记eule ...

  3. NYOJ 998

    这道题是欧拉函数的使用,这里简要介绍下欧拉函数. 欧拉函数定义为:对于正整数n,欧拉函数是指不超过n且与n互质的正整数的个数. 欧拉函数的性质:1.设n = p1a1p2a2p3a3p4a4...pk ...

  4. 【webGl】threejs实现一个简单的动画-弹跳的小球

    在这里,我们将动态画面简称为动画(animation).正如动画片的原理一样,动画的本质是利用了人眼的视觉暂留特性,快速地变换画面,从而产生物体在运动的假象.而对于Three.js程序而言,动画的实现 ...

  5. HTML5 Canvas彩色小球碰撞运动特效

    脚本简介 HTML5 Canvas彩色小球碰撞运动特效是一款基于canvas加面向对象制作的运动小球动画特效.   效果展示 http://hovertree.com/texiao/html5/39/ ...

  6. 纯CSS3实现3D跳动小球

    请使用Chrome,火狐的浏览器查看本页面,使用IE将看不到效果.如果在本页看不到一个跳动的小球,请确定您的浏览器支持CSS3,或者访问http://keleyi.com/a/bjac/iphgrtq ...

  7. HTML5 随机弹跳的小球

    查看效果:http://keleyi.com/a/bjad/tc1y11dy.htm Chrome效果图: 火狐效果图:推荐:http://hovertree.com/texiao/css3/18/ ...

  8. NYOJ 333

    http://www.cppblog.com/RyanWang/archive/2009/07/19/90512.aspx?opt=admin 欧拉函数 E(x)表示比x小的且与x互质的正整数的个数. ...

  9. WPF实现物理效果 拉一个小球

    一直以来都对物理效果有神秘感,完全不知道怎么实现的.直到看到了周银辉在老早前写的一篇博客:http://www.cnblogs.com/zhouyinhui/archive/2007/06/23/79 ...

随机推荐

  1. iframe 跨域请求

    iframe.contentWindow 兼容各个浏览器,可取得子窗口的 window 对象. iframe.contentDocument Firefox 支持,> ie8 的ie支持.可取得 ...

  2. freeswitch中集成使用ekho实现TTS功能一

    Linux下安装freeswitch并集成ekho实现TTS 1. linux下安装freeswitch就不多介绍了,具体链接网址: http://www.8000hz.com/archives/14 ...

  3. PHP面向对象之对象和引用

    在PHP中对象类型和简单变量类型表现可以说是大相径庭,很多数据类型都要可以在写时进行复制,如当写代码$a=$b时,两个变量因为赋予相同的值而告终.所以需要注意的是,这种情况用在对象时就会完全不同了. ...

  4. 深入理解Node.js中的垃圾回收和内存泄漏的捕获

    深入理解Node.js中的垃圾回收和内存泄漏的捕获 文章来自:http://wwsun.github.io/posts/understanding-nodejs-gc.html Jan 5, 2016 ...

  5. 安装MySQL5.7.18遇到的坑

    最近才注意到MySQL的各个版本之间差别还挺大的,比如5.5.x版本的timestamp类型列只能有一个设置为default CURRENT_TIMESTAMP的,于是尝试了换成一个新版本是mysql ...

  6. git checkout cannot stat permission denied

    https://stackoverflow.com/questions/5970879/git-rebase-error-cannot-stat-file-permission-denied 退出vi ...

  7. Luogu-3346 [ZJOI2015]诸神眷顾的幻想乡

    \(trie\)树建广义后缀自动机: \(dfs\)遍历\(trie\)树,将树上的一个节点插入\(sam\)时,将他的\(fa\)在\(sam\)上所在的节点作为\(last\) #include& ...

  8. 初探MyBatis之HelloWorld(一)

    官方地址:https://github.com/mybatis/mybatis-3 准备: 官方中文文档地址:http://www.mybatis.org/mybatis-3/zh/getting-s ...

  9. Compaction介绍

    Compaction介绍 Compaction是buffer->flush->merge的Log-Structured Merge-Tree模型的关键操作,主要起到如下几个作用: 1)合并 ...

  10. DB2导入导出方法总结

    1.导出 DEL 文本文件  export to D:\T_TESTTABLE20121220.del of del select * from T_TESTTABLE 2.导出 ixf 文本文件.i ...