题目连接:https://www.hackerrank.com/contests/codestorm/challenges/game-with-a-boomerang

上一篇博客不知怎么复制过来题目,排版惨不忍睹。。。所以这个只好直接放链接吧

题意是n个土著人,编号1~n。围成一圈,然后从1号开始扔飞镖,如果是奇数个人的圈的话,那这个扔飞镖的人没有对应的人,扔飞镖的人淘汰。如果是偶数个人的圈的话,将对面编号淘汰。

这样围成一圈之后,进行n-1轮,每一轮淘汰掉一个人,问最终剩下的人的编号。

没做过这样的题,全无思路。然后上离散课的时候拿纸笔画,发现偶数n的时候就是等于奇数n-1的时候加一的情况,然后发现可以递推,奇数的时候也是有规律的。于是写了这么一个程序。

代码:

  1. #include <iostream>
  2. #include <algorithm>
  3. #include <cmath>
  4. #include <vector>
  5. #include <string>
  6. #include <cstring>
  7. #pragma warning(disable:4996)
  8. using namespace std;
  9.  
  10. typedef long long ll;
  11. //const int maxn = 1e18;
  12.  
  13. ll n;
  14. //ll val[1000000000000000000];
  15.  
  16. ll cal(ll x)
  17. {
  18. ll i;
  19. ll ori = 1;
  20. for (i = 2; i <= x; i++)
  21. {
  22. if (i & 1)
  23. {
  24. ori = ori + 1;
  25. }
  26. else
  27. {
  28. if (ori < i / 2)
  29. {
  30. ori = ori + 1;
  31. }
  32. else
  33. {
  34. ori = ori + 2;
  35. if (ori > i)
  36. {
  37. ori = ori - i;
  38. }
  39. }
  40. }
  41. }
  42. return ori;
  43. }
  44.  
  45. int main()
  46. {
  47. //freopen("i.txt","r",stdin);
  48. //freopen("o.txt","w",stdout);
  49.  
  50. int test;
  51. scanf("%d", &test);
  52.  
  53. while (test--)
  54. {
  55. scanf("%lld", &n);
  56. printf("%lld\n", cal(n));
  57. }
  58. //system("pause");
  59. return 0;
  60. }

对了很多个test,但是tle了,我本来想也是会tle的。。。

于是举了1000个数找规律,找到的规律就是发现了断点都是4n-2,然后每个数只跟其断点的大小有关系,剩下的也没什么了。

做出来的时候特别高兴,但现在觉得这个题目貌似也不过如此啊。。。果然自己还是。。。。

代码:

  1. #include <iostream>
  2. #include <algorithm>
  3. #include <cmath>
  4. #include <vector>
  5. #include <string>
  6. #include <cstring>
  7. #pragma warning(disable:4996)
  8. using namespace std;
  9.  
  10. typedef long long ll;
  11.  
  12. ll n;
  13. ll val[100];
  14.  
  15. void init()
  16. {
  17. ll i;
  18. val[1] = 1;
  19. for (i = 2;; i++)
  20. {
  21. val[i] = val[i - 1] * 4 - 2;
  22. if (val[i] > 1e18)
  23. break;
  24. }
  25. }
  26. ll cal(ll x)
  27. {
  28. int i;
  29. for (i = 1; i <= 32; i++)
  30. {
  31. if (x - val[i] < 0)
  32. break;
  33. }
  34. i--;
  35.  
  36. ll y = x - val[i];
  37. ll sum;
  38. ll v;
  39. ll temp;
  40. if (y < val[i])
  41. return y + 1;
  42. else
  43. {
  44. temp = x - 2 * val[i];
  45. v = temp / 2;
  46. sum = v + (v + 1) * 2;
  47. if (temp & 1)
  48. {
  49. sum++;
  50. }
  51. return val[i] + sum;
  52. }
  53. }
  54. int main()
  55. {
  56. //freopen("i.txt", "r", stdin);
  57. //freopen("o.txt", "w", stdout);
  58.  
  59. init();
  60. int test;
  61. scanf("%d", &test);
  62.  
  63. while (test--)
  64. {
  65. scanf("%lld", &n);
  66. printf("%lld\n", cal(n));
  67. }
  68. //system("pause");
  69. return 0;
  70. }

版权声明:本文为博主原创文章,未经博主允许不得转载。

Codestorm:Game with a Boomerang的更多相关文章

  1. Codestorm:Counting Triangles 查各种三角形的个数

    题目链接:https://www.hackerrank.com/contests/codestorm/challenges/ilia 这周六玩了一天的Codestorm,这个题目是真的很好玩,无奈只做 ...

  2. JavaScript面试的完美指南(开发者视角)

    为了说明 JS 面试的复杂性,首先,请尝试给出以下结果: onsole.log(2.0 == "2" == new Boolean(true) == "1") ...

  3. java web 开发三剑客 -------电子书

    Internet,人们通常称为因特网,是当今世界上覆盖面最大和应用最广泛的网络.根据英语构词法,Internet是Inter + net,Inter-作为前缀在英语中表示“在一起,交互”,由此可知In ...

  4. 所有selenium相关的库

    通过爬虫 获取 官方文档库 如果想获取 相应的库 修改对应配置即可 代码如下 from urllib.parse import urljoin import requests from lxml im ...

  5. 转:Twitter.com在用哪些Javascript框架?

    原文来自于:http://blog.jobbole.com/63964/ 我一直在研究twitter.com使用的一些UI框架.下面是这些框架的清单(大部分是Javascript框架).如果你发现有些 ...

  6. 【leetcode】1037. Valid Boomerang

    题目如下: A boomerang is a set of 3 points that are all distinct and not in a straight line. Given a lis ...

  7. IDA PRO:庆祝成立创新 30 周年

    今天,IDA 已经三十岁了.为了纪念周年纪念,我们将描述史诗旅程的开始和主要里程碑. 背景 在 1990 年代初期,DOS 是最流行的 PC 操作系统,主要是 8086,偶尔有 80286(80386 ...

  8. 【LeetCode】1037. Valid Boomerang 解题报告(C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 中学数学题 日期 题目地址:https://leet ...

  9. In-Memory:内存数据库

    在逝去的2016后半年,由于项目需要支持数据的快速更新和多用户的高并发负载,我试水SQL Server 2016的In-Memory OLTP,创建内存数据库实现项目的负载需求,现在项目接近尾声,系统 ...

随机推荐

  1. svnserve: Can’t bind server socket: Address already in use报错解决办法

    最近在学习自己搭建SVN服务,意外的报错 svnserve: Can’t bind server socket: Address already in use 于是google了下,原来是 已经启动了 ...

  2. AF(操作者框架)系列(1)-LabVIEW中的模块化应用概述

    一.引子 在前面对LabVIEW介绍的文章中,关于框架开发的内容涉及很少.为了讲解操作者框架(Actor Framework)的优缺点,也只是拿出来QDSM(Queue-Driven State Ma ...

  3. SpringBoot简要介绍

    一 SpringBoot介绍 1.1 先从Spring谈起 我们知道Spring是重量级企业开发框架 Enterprise JavaBean(EJB) 的替代品,Spring为企业级Java开发提供了 ...

  4. spark实验(一)--spark安装(1)

    一.实验目的 (1)掌握 Linux 虚拟机的安装方法.Spark 和 Hadoop 等大数据软件在 Linux 操作系统 上运行可以发挥最佳性能,因此,本教程中,Spark 都是在 Linux 系统 ...

  5. Linux下清空文件的3种方法

    1.echo -n > test.log #-n选项可以去掉空行 2.cat /dev/null > test.log 3.truncate -s 0 test.log

  6. django annotate()的使用

    https://www.zmrenwu.com/post/18/ 博客文章通常都有分类,有时候我们会看到分类名后面还跟着该分类下的文章数量.前面我们通过学习 django 博客开发入门教程搭建了一个小 ...

  7. .net使用rabbitmq安装操作

    自己在windows安装rabbitmq时,遇到了很多坑,最恶心的就是版本不匹配的问题,所以自己写了一篇总结,本文章安装的Erlang为8.2,rabbitmq为3.5.6 1 安装rabbitmq, ...

  8. Python学习笔记007

    赋值运算符 num+=1 num=num+1 num-=1 num=num-1 num*=2 num=num*2 num/=2 num=num/2 num//=2 num=num//2 num%=2 ...

  9. 使用eclipse创建一个简单的Java Web应用程序

    关于Java JDK/JRE.Tomcat的配置等等都没什么好说的,主要记录一下使用Eclipse创建web工程时的一些点以及说一说自己用IDEA的创建失败的过程(IDEA没运行成功...暂时不想弄了 ...

  10. CPD

    CPD,Cost per day的缩写,意思是按天收费,是一种广告合作方式.在实际的广告合作中根据行业不同还包括Cost per Download的缩写含义,意思是依据实际下载量收费.