https://ac.nowcoder.com/acm/contest/847/C

在blueland上有 n n个水果店,它们的编号依次为 0,1,2...n−1 0,1,2...n−1。奇妙的是,每个水果店都只卖一种水果,且这些水果店卖的水果种类都各不相同。
在每个水果店有一个传送门,且这些传送门也有各自的编号,其中 i i号水果店的传送门编号为 Ai Ai,每个传送门的编号也各不相同,且是 [0,n−1] [0,n−1]中的一个整数。简单的说, A0A1A2...An−1 A0A1A2...An−1 0∼n−1 0∼n−1的一个排列
lililalala初始位于 0 0号水果店,现在他想买到全部的 n n种水果,但是他并不认识路,所以只能通过传送门往来于水果店并通过固定的流程买水果:
当他到达 i i号水果店时,如果之前没有到过这个水果店,那么lililalala会买下这种水果并且通过这个水果店的传送门传送到 (i+Ai)modn (i+Ai)modn号水果店;
如果之前已经到过这个水果店,那么他就立即停止买水果的流程。
请输出一种使得lililalala可以买到全部 n n种水果的一种传送门编号序列,或者判定不存在这样的序列。

输入描述:

  1. 仅一行一个整数 n(1n100000) n(1n100000)。

输出描述:

如果存在符合题目要求的序列:
输出一行 n n个整数--符合题目要求的序列,如果有多个序列满足要求,输出任意一个即可。
输出需要保证:
∀i∈[0,n−1],Ai∈[0,n−1]∀i∈[0,n−1],Ai∈[0,n−1]
∀i,j∈[0,n−1],满足Ai≠Aj如果i≠j∀i,j∈[0,n−1],满足Ai≠Aj如果i≠j
如果不存在符合题目要求的序列,输出 −1 −1。
示例1

输入

  1. 8

输出

  1. 6 3 7 2 0 5 1 4

说明

lililalala经过水果店的顺序是:
 0→6→7→3→5→2→1→4 0→6→7→3→5→2→1→4
答案可能不止一种。
示例2

输入

  1. 10

输出

  1. 8 4 9 1 3 0 6 2 5 7

说明

lililalala经过水果店的顺序是:
 0→8→3→4→7→9→6→2→1→5 0→8→3→4→7→9→6→2→1→5
  1. 答案可能不止一种。
    解题:
    起点是0,传送到(n-1)号店,再传送到1号店,再传送到n-2号店,再传送到2号店,以此类推,直到n/2传送回0
  1. 数组jump存储传送到的店号,数组存储传送门的编号,i表示当前水果店
    (i+door[i])%n=jump[i]
    逆推door[i]:
    (i+door[i])/n=x;
    door[i]=x*n+jump[i]-i;
    手撸n为偶数的情况,前后跳。
  1. 比如:n=8
    下标i: 0 1 2 3 4 5 6 7
    jump[i]:7 6 5 4 0 3 2 1
    door[i]:7 5 3 1 0 6 4 2
    显然n/2前面的x都为0n/2后面的x都为1n/2特判。
    手撸n为奇数的情况,举例n=35,撸不出来。直接输出-1
    提交一发wa后想到特判n=1的情况。
  1. #include<stdio.h>
  2. #include<iostream>
  3. #include<algorithm>
  4. #include<cstring>
  5. #include<math.h>
  6. #include<string>
  7. #include<map>
  8. #include<queue>
  9. #define ll long long
  10. #define inf 0x3f3f3f3f
  11. using namespace std;
  12.  
  13. int n;
  14. int jump[];///传送到的店号
  15. int door[];///传送门的编号
  16.  
  17. int main()
  18. {
  19. while(cin>>n)
  20. {
  21. if(n==)
  22. printf("0\n");
  23. else if(n%)
  24. printf("-1\n");
  25. else
  26. {
  27. int len=n/;
  28. for(int i=;i<n;i++)
  29. {
  30. if(i<len)
  31. {
  32. jump[i]=n--i;
  33. }
  34. else if(i==len)
  35. jump[i]=;
  36. else
  37. jump[i]=n-i;
  38. }
  39. for(int i=;i<n;i++)
  40. {
  41. if(i<len)
  42. {
  43. door[i]=jump[i]-i;
  44. }
  45. else if(i==len)
  46. door[i]=;
  47. else
  48. door[i]=n+jump[i]-i;
  49.  
  50. }
  51. /*打印观察规律
  52. for(int i=0;i<n;i++)
  53. if(i!=n-1)
  54. printf("%d ",i);
  55. else
  56. printf("%d\n",i);
  57. for(int i=0;i<n;i++)
  58. if(i!=n-1)
  59. printf("%d ",jump[i]);
  60. else
  61. printf("%d\n",jump[i]);
  62. */
  63. for(int i=;i<n;i++)
  64. if(i!=n-)
  65. printf("%d ",door[i]);
  66. else
  67. printf("%d\n",door[i]);
  68. }
  69. }
  70. return ;
  71. }
  1.  
  1.  

Buy Fruits-(构造)的更多相关文章

  1. Can peel peel solve pesticide problem

    Can peel peel solve pesticide problem? Middle peasants medicinal modern agriculture more and more, t ...

  2. Codeforces Round #381 (Div. 2) A B C 水 构造

    A. Alyona and copybooks time limit per test 1 second memory limit per test 256 megabytes input stand ...

  3. CodeForces 12C Fruits

    Fruits Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u Submit Stat ...

  4. 魔法方法:构造和析构 - 零基础入门学习Python041

    魔法方法:构造和析构 让编程改变世界 Change the world by program 构造和析构 什么是魔法方法呢?我们来系统总结下: - 魔法方法总是被双下划线包围,例如__init__ - ...

  5. Pronunciation Guide for 25 Common Fruits

    Pronunciation Guide for 25 Common Fruits Share Tweet Share Tagged With: Vocabulary Words Know how to ...

  6. 解题报告Best Time to Buy and Sell Stock with Cooldown

    题目 Say you have an array for which the ith element is the price of a given stock on day i. Design an ...

  7. UVA 1151 Buy or Build MST(最小生成树)

    题意: 在平面上有n个点,要让所有n个点都连通,所以你要构造一些边来连通他们,连通的费用等于两个端点的欧几里得距离的平方.另外还有q个套餐,可以购买,如果你购买了第i个套餐,该套餐中的所有结点将变得相 ...

  8. 学习笔记:Maven构造版本号的方法解决浏览器缓存问题

    需要解决的问题 在做WEB系统开发时,为了提高性能会利用浏览器的缓存功能,其实即使不显式的申明缓存,现代的浏览器都会对静态文件(js.css.图片之类)缓存.但也正因为这个问题导致一个问题,就是资源的 ...

  9. 一步步构造自己的vue2.0+webpack环境

    前面vue2.0和webpack都已经有接触了些(vue.js入门,webpack入门之简单例子跑起来),现在开始学习如何构造自己的vue2.0+webpack环境. 1.首先新建一个目录vue-wk ...

随机推荐

  1. influx db

    1.查看数据库中的tag keys:     如果需要查看field的直接改 > show tag keys on test; name: garage_pc_overviewtagKey--- ...

  2. Java的多路分支代码,感觉有点意思

    /** * @Author hty * @Date 2019-12-16 16:39 * @Version 1.0 */ import java.util.Random; // 比赛结果 enum O ...

  3. .NET CORE 中的缓存使用

    Net Framewoke的缓存 1.1 System.Web.Caching System.Web.Caching应该是我们最熟悉的缓存类库了,做ASP.NET开发时用到缓存基本都是使用的这个缓存组 ...

  4. Go语言入门——hello world

    Go 语言源代码文件扩展名是.go. 知识点:1. go语言代码的第1行必须声明包2. 入口的go语言代码(包含main函数的代码文件)的包必须是main,否则运行go程序会显示go run: can ...

  5. FileUpload上传多张照片

    <asp:FileUpload ID="uploaderInput" runat="server" multiple="multiple&quo ...

  6. ad域的那些事儿

    先附上参考链接,有空再来整理 基础知识:https://www.cnblogs.com/cnjavahome/p/9029665.html ad域的操作:https://www.cnblogs.com ...

  7. SQL Server中查找包含某个文本的存储过程 SQL 查找存储过程中出现过的文字怎么查询 查询整个数据库中出现的文本 sql 全局搜索

    --将text替换成你要查找的内容SELECT name, *FROM sysobjects o, syscomments sWHERE o.id = s.id AND text LIKE '%tex ...

  8. Big Data Hubris:"大数据傲慢"问题

    大数据的傲慢与偏见— 读后心得 数据模型研究者必看的书 原文链接: https://medium.com/@iven00000000/%E5%A4%A7%E6%95%B8%E6%93%9A%E7%9A ...

  9. PHP-FPM的相关知识的深度解释

    一.需要搞清楚几个名词概念 1.          CGI(Common Gateway Interface,CGI)通用网关接口, 是Web 服务器运行时外部程序的规范,按CGI 编写的程序可以扩展 ...

  10. Java自学-接口与继承 内部类

    Java 内部类 内部类分为四种: 非静态内部类 静态内部类 匿名类 本地类 步骤 1 : 非静态内部类 非静态内部类 BattleScore "战斗成绩" 非静态内部类可以直接在 ...