题目描述

Koishi决定走出幻想乡成为数学大师!

Flandre听说她数学学的很好,就给Koishi出了这样一道构造题:

Task1:试判断能否构造并构造一个长度为的排列,满足其个前缀和在模的意义下互不相同

Taks2:试判断能否构造并构造一个长度为的排列,满足其个前缀积在模的意义下互不相同

按照套路,Koishi假装自己根本不会捉,就来找你帮忙辣。

输入输出格式

输入格式:

第一行两个整数,分别表示Task类型和测试点内的数据组数。

接下来行,每行一个整数表示每组数据中的

输出格式:

为了方便SPJ的编写,您需要遵从以下格式输出。

对于每组数据仅包含一行输出:

  1. 如果您认为当前数据不存在符合题意的构造,只需输出一个整数

  2. 如果您认为当前数据存在符合题意的构造却不会构造,只需输出一个整数

  3. 如果您认为当前数据存在符合题意的构造并成功构造,则需要先输出一个整数,再输出个整数表示构造的方案。

每两个整数之间需要有空格作为分隔符

输入输出样例

输入样例#1:

1 1
8
输出样例#1:

2 8 7 6 5 4 3 2 1
输入样例#2:

2 1
11
输出样例#2:

2 1 2 3 5 10 6 7 4 9 8 11

说明

对于每组数据

  1. 如果您对于构造的存在性判断正确,您将会得到的分数,若您的构造符合题意或者确实不存在符合题意的构造,您将会得到剩余的的分数。

  2. 如果您对于构造的存在性判断不正确,您将不会得到任何分数。

对于每组测试点,您的得分将是本组数据点中得分的最小值。

测试点类型1:10分,满足

测试点类型2:40分,满足

测试点类型3:10分,满足

测试点类型4:40分,满足

对于所有测试点,满足


当时想出如何判断了但是不会构造

前缀和不存在就是n|(1+2+...+n)

前缀积不存在就是n|(n-1)!

直接上标解了:

Task1:

通过爆搜观察发现,除了  以外的奇数都无解,偶数都有解。

证明:由于  ,也就是说  必须放于第一位,前缀和第一位一定是  ,奇数情况下又由于  ,也就是说前缀和最后一位一定是  ,导致矛盾。

打表观察,每个偶数搜出来的方案都有  ,不难证明其正确性。

Task2:

通过爆搜观察发现,除了  以外的合数都无解,质数都有解。

证明:考虑到  ,那么前缀积的最后一项一定是  ,也就是说最后一项尽量放  ,那么这要求  ,发现只有  和质数胜任这个要求。

打表观察,每个质数搜出来的前缀积方案都有  ,也就是说第  位就是  ,通过逆元算出来就可以了。1和4的情况特判即可。

醉了快速幂又写成if(b)......

//
// main.cpp
// CC
//
// Created by Candy on 2017/2/2.
// Copyright © 2017年 Candy. All rights reserved.
// #include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
using namespace std;
typedef long long ll;
inline int read(){
char c=getchar();int x=,f=;
while(c<''||c>''){if(c=='-')f=-; c=getchar();}
while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
return x*f;
}
int task,T,n;
void solve1(int n){
if(n==) puts("2 1");
else if(n&) puts("");
else{
printf("2 ");
printf("%d ",n);
for(int i=;i<n;i++){
if(i&) printf("%d ",i);
else printf("%d ",n-i);
}
puts("");
}
}
inline bool isP(int n){
if(n==) return true;
int m=sqrt(n)+;
for(int i=;i<=m;i++) if(n%i==) return false;
return true;
}
ll powMod(ll a,ll b,ll MOD){
ll ans=;
for(;b;b>>=,a=(a*a)%MOD)
if(b&) ans=(ans*a)%MOD;
return ans;
}
void solve2(int n){
if(n==) puts("2 1");
else if(n==) puts("2 1 2");
else if(n==) puts("2 1 3 2 4");
else if(!isP(n)) puts("");
else{
printf("2 1 ");
for(int i=;i<=n;i++){
printf("%lld ",(i*powMod(i-,n-,n)-)%n+);
}
puts("");
}
}
int main(int argc, const char * argv[]) {
task=read();T=read();
while(T--){
n=read();
if(task==) solve1(n);
else solve2(n);
}
return ;
}

C 洛谷 P3599 Koishi Loves Construction [构造 打表观察]的更多相关文章

  1. 洛谷P3599 Koishi Loves Construction 构造

    正解:构造 解题报告: 传送门! 这题俩问嘛,就分成两个问题港QwQ 就按顺序趴,先港第一问QwQ 首先要发现,n在膜n意义下就是0嘛 那作为前缀和的话显然它就只能放在第一个 然后再想下,发现,如果n ...

  2. P3599 Koishi Loves Construction——构造题

    题目 Task1:试判断能否构造并构造一个长度 $n$ 的 $1...n$ 的排列,满足其 $n$ 个前缀和在模 $n$ 的意义下互不相同 Task2:试判断能否构造并构造一个长度 $n$ 的 $1. ...

  3. 【题解】P3599 Koishi Loves Construction

    [题解]P3599 Koishi Loves Construction \(\mod n\) 考虑如何构造,发现\(n\)一定在第一位,不然不行.\(n\)一定是偶数或者是\(1\),不然 \(n|\ ...

  4. 洛谷P3602 Koishi Loves Segments(贪心,multiset)

    洛谷题目传送门 贪心小水题. 把线段按左端点从小到大排序,限制点也是从小到大排序,然后一起扫一遍. 对于每一个限制点实时维护覆盖它的所有线段,如果超过限制,则贪心地把右端点最大的线段永远删去,不计入答 ...

  5. E 洛谷 P3598 Koishi Loves Number Theory[数论]

    题目描述 Koishi十分喜欢数论. 她的朋友Flandre为了检测她和数论是不是真爱,给了她一个问题. 已知 给定和个数,求对取模. 按照套路,呆萌的Koishi当然假装不会做了,于是她来向你请教这 ...

  6. D 洛谷 P3602 Koishi Loves Segments [贪心 树状数组+堆]

    题目描述 Koishi喜欢线段. 她的条线段都能表示成数轴上的某个闭区间.Koishi喜欢在把所有线段都放在数轴上,然后数出某些点被多少线段覆盖了. Flandre看她和线段玩得很起开心,就抛给她一个 ...

  7. 洛谷P3602 Koishi Loves Segments 贪心

    正解:贪心 解题报告: 传送门! 首先在学习贪心的入门题的时候我们就知道,当x=1的时候,也就是每条线段不能相交的时候的做法——就按右端点排序然后能选就选,也就是会议安排问题,原因显然?就你选右端点更 ...

  8. 题解-Koishi Loves Construction

    题解-Koishi Loves Construction 前缀知识 质数 逆元 暴搜 Koishi Loves Construction 给定 \(X\),\(T\) 组测试数据,每次给一个 \(n\ ...

  9. 洛谷 P1580 yyy loves Easter_Egg I

    洛谷 P1580 yyy loves Easter_Egg I 题解: 队列+字符串 #include <cstdio> #include <string> #include ...

随机推荐

  1. JS 监听浏览器各个标签间的切换

    以前看到过一些网页,在标签切换到其它地址时,网页上的标题上会发生变化,一直不知道这个是怎么做的,最近查了一些资料才发现有一个 visibilitychange 事件就可以搞定,这里将介绍一下页面可见性 ...

  2. Npm vs Yarn 之备忘大全

    有则笑话,如此讲到:"老丈人爱吃核桃,昨天买了二斤陪妻子送去,老丈人年轻时练过武,用手一拍核桃就碎了,笑着对我说:你还用锤子,你看我用手就成.我嘴一抽,来了句:人和动物最大的区别就是人会使用 ...

  3. tree conflict svn 怎么解决

    如果自己和其他人修改了同一个文件,而他已经更新到SVN,你commit时就会出现冲突,如何解决呢? 方法/步骤 使用SVN时,更新一个自己修改的文件到服务器,出现冲突,因为其他同事也修改了这个文件并且 ...

  4. dubbo源码—Service Reply

    dubbo通过netty将请求发送到provider的时候,provider之前已经启动好的NettyServer监听指定端口的时候会收到来自consumer的请求,将通过网络发送来的二进制编码成Re ...

  5. 2017年 JavaScript 框架回顾 -- 后端框架

    本文是2017年 JavaScript 框架回顾系列的最后的一篇文章,主要介绍 JavaScript 的后端框架情况. 从上图中可以看到,Express 作为用 JavaScript 编写的后端服务的 ...

  6. mmap 测试的一些坑

    最近遇到一个mmap的问题,然后为了测试该问题,写了如下测试代码: #include <sys/mman.h> #include <sys/stat.h> #include & ...

  7. 2017-06-24(chgrp umask alias unalias)

    chgrp chgrp  组名  文件名 chgrp root newfile   将newfile的所属组修改为root umask umask 查看默认权限 0 022 文件的特殊权限 文件的默认 ...

  8. javascript函数创建

    函数声明 function add(a,b){ return a+b } 函数表达式 <!--一般函数表达式--> var add = function(){ } <!--立即声明函 ...

  9. Traits技法

    扮演"特性萃取机"角色,萃取各个迭代器的特性(迭代器的相应类型) 模板特例化:提供一份template定义式,而其本身仍为templatization 通过class templa ...

  10. 一、Python表达式基础

    Python 能执行简单的计算器的功能: 如>>2+2 ==> 4,1/2==>0.5或者这样写1/2.0==>0.5(取浮点型) 1//2 ==>0 (" ...