C 洛谷 P3599 Koishi Loves Construction [构造 打表观察]
题目描述
Koishi决定走出幻想乡成为数学大师!
Flandre听说她数学学的很好,就给Koishi出了这样一道构造题:
Task1:试判断能否构造并构造一个长度为的
的排列,满足其
个前缀和在模
的意义下互不相同
Taks2:试判断能否构造并构造一个长度为的
的排列,满足其
个前缀积在模
的意义下互不相同
按照套路,Koishi假装自己根本不会捉,就来找你帮忙辣。
输入输出格式
输入格式:
第一行两个整数和
,分别表示Task类型和测试点内的数据组数。
接下来行,每行一个整数表示每组数据中的
输出格式:
为了方便SPJ的编写,您需要遵从以下格式输出。
对于每组数据仅包含一行输出:
如果您认为当前数据不存在符合题意的构造,只需输出一个整数
如果您认为当前数据存在符合题意的构造却不会构造,只需输出一个整数
- 如果您认为当前数据存在符合题意的构造并成功构造,则需要先输出一个整数
,再输出
个整数表示构造的方案。
 
每两个整数之间需要有空格作为分隔符
输入输出样例
1 1
8
2 8 7 6 5 4 3 2 1
2 1
11
2 1 2 3 5 10 6 7 4 9 8 11
说明
对于每组数据
如果您对于构造的存在性判断正确,您将会得到
的分数,若您的构造符合题意或者确实不存在符合题意的构造,您将会得到剩余的
的分数。
- 如果您对于构造的存在性判断不正确,您将不会得到任何分数。
 
对于每组测试点,您的得分将是本组数据点中得分的最小值。
测试点类型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 [构造 打表观察]的更多相关文章
- 洛谷P3599 Koishi Loves Construction 构造
		
正解:构造 解题报告: 传送门! 这题俩问嘛,就分成两个问题港QwQ 就按顺序趴,先港第一问QwQ 首先要发现,n在膜n意义下就是0嘛 那作为前缀和的话显然它就只能放在第一个 然后再想下,发现,如果n ...
 - P3599 Koishi Loves Construction——构造题
		
题目 Task1:试判断能否构造并构造一个长度 $n$ 的 $1...n$ 的排列,满足其 $n$ 个前缀和在模 $n$ 的意义下互不相同 Task2:试判断能否构造并构造一个长度 $n$ 的 $1. ...
 - 【题解】P3599 Koishi Loves Construction
		
[题解]P3599 Koishi Loves Construction \(\mod n\) 考虑如何构造,发现\(n\)一定在第一位,不然不行.\(n\)一定是偶数或者是\(1\),不然 \(n|\ ...
 - 洛谷P3602 Koishi Loves Segments(贪心,multiset)
		
洛谷题目传送门 贪心小水题. 把线段按左端点从小到大排序,限制点也是从小到大排序,然后一起扫一遍. 对于每一个限制点实时维护覆盖它的所有线段,如果超过限制,则贪心地把右端点最大的线段永远删去,不计入答 ...
 - E 洛谷 P3598 Koishi Loves Number Theory[数论]
		
题目描述 Koishi十分喜欢数论. 她的朋友Flandre为了检测她和数论是不是真爱,给了她一个问题. 已知 给定和个数,求对取模. 按照套路,呆萌的Koishi当然假装不会做了,于是她来向你请教这 ...
 - D 洛谷 P3602 Koishi Loves Segments [贪心 树状数组+堆]
		
题目描述 Koishi喜欢线段. 她的条线段都能表示成数轴上的某个闭区间.Koishi喜欢在把所有线段都放在数轴上,然后数出某些点被多少线段覆盖了. Flandre看她和线段玩得很起开心,就抛给她一个 ...
 - 洛谷P3602 Koishi Loves Segments 贪心
		
正解:贪心 解题报告: 传送门! 首先在学习贪心的入门题的时候我们就知道,当x=1的时候,也就是每条线段不能相交的时候的做法——就按右端点排序然后能选就选,也就是会议安排问题,原因显然?就你选右端点更 ...
 - 题解-Koishi Loves Construction
		
题解-Koishi Loves Construction 前缀知识 质数 逆元 暴搜 Koishi Loves Construction 给定 \(X\),\(T\) 组测试数据,每次给一个 \(n\ ...
 - 洛谷 P1580 yyy loves Easter_Egg I
		
洛谷 P1580 yyy loves Easter_Egg I 题解: 队列+字符串 #include <cstdio> #include <string> #include ...
 
随机推荐
- android文件管理器源码、斗鱼直播源码、企业级erp源码等
			
Android精选源码 文件清理管理器 自定义水平带数字的进度条以及自定义圆形带数字的进度条 利用sectionedRecyclerViewAdapter实现分组列表的recyclerView源码 流 ...
 - c++(线性队列)
			
这里的线性结构实际上指的就是连续内存的意思,只不过使用“线性”这个词显得比较专业而已.前面一篇博客介绍了现象结构的处理方法,那么在这个基础之上我们是不是添加一些属性形成一种新的数据结构类型呢?答案是肯 ...
 - 利用Selenium+PhantomJS 实现截图
			
using OpenQA.Selenium; using OpenQA.Selenium.PhantomJS; using System; using System.Drawing; using Sy ...
 - c# tolist()  浅析
			
在介绍tolist()的时候我先个大家介绍一下linq的延迟加载: var products = new List<Product> { , Category = "Electr ...
 - 自己动手实现一个简单的JSON解析器
			
1. 背景 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.相对于另一种数据交换格式 XML,JSON 有着诸多优点.比如易读性更好,占用空间更少等.在 ...
 - linux下 ls -l 命令显示结果每一列代表什么意思
			
第一个栏位,表示文件的属性.Linux的文件基本上分为三个属性:可读(r),可写(w),可执行(x).但是这里有十个格子可以添(具体程序实现时,实际上是十个bit位).第一个小格是特殊表示格,表示目录 ...
 - robots书写说明:
			
"User-Agent"搜索引擎的名字. 针对所有搜索引擎写法:User-Agent: *,针对百度搜索引擎写法:User-Agent:Baiduspider "Allo ...
 - 直接请求转发(Forward)和间接请求转发(Redirect)两种区别?
			
用户向服务器发送了一次HTTP请求,该请求肯能会经过多个信息资源处理以后才返回给用户,各个信息资源使用请求转发机制相互转发请求,但是用户是感觉不到请求转发的.根据转发方式的不同,可以区分为直接请求转发 ...
 - scrapy_随机user-agent
			
什么是user-agent? 用户代理,服务器识别用户的操作系统,浏览器类型和渲染引擎,不同浏览器的user-agent是不同的 如何随机更改user-agent? 1. 在setting中添加use ...
 - JDK 中的设计模式应用实例
			
在 JDK(Java Development Kit)类库中,开发人员使用了大量设计模式,正因为如此,我们可以在不修改 JDK 源码的前提下开发出自己的应用软件.研究 JDK 类库中的模式实例也不 ...