题解 math
赛时用一个奇怪的方法过掉了
首先\(b_i\)的有效范围是\([0, k-1]\)
发现不同的\(a_i*b_i\)会有很多重的
考虑把\(a_i\%k\),然后由小到大排序
按顺序扫,如果某个\(a_i\)已经可以被某个\(a_j\%k\)的倍数表示出来,那这个\(a_i\)就无效化了
这个可以用埃氏筛实现
最后会剩下一些仍有效的\(a_i\),但由于一些性质(我不太懂)剩下的数会极少,一般只剩下一个
那就可以\(O(k^n)\)暴力处理了
这个性质很有趣,随机数据几乎卡不掉,跑了半个小时才跑出来一个剩10个数的
然后正解:
一个看着很显然但遇到题不容易想到的结论:
- \(ax+by=z\) 有整数解的条件是 \(gcd(a, b)|z\)
所以 \((\sum a_i*b_i)\%k\) 就一定是 \(gcd(a_i, a_{i+1}, ...)\) 的倍数
那求个gcd,不断乘\(k\)就行了
所以我从哪能联想到这个结论啊
Code:
#include <bits/stdc++.h>
using namespace std;
#define INF 0x3f3f3f3f
#define N 1000100
#define ll long long
#define ld long double
#define usd unsigned
#define ull unsigned long long
//#define int long long
#define getchar() (p1==p2&&(p2=(p1=buf)+fread(buf, 1, 1<<21, stdin)), p1==p2?EOF:*p1++)
char buf[1<<21], *p1=buf, *p2=buf;
inline int read() {
int ans=0, f=1; char c=getchar();
while (!isdigit(c)) {if (c=='-') f=-f; c=getchar();}
while (isdigit(c)) {ans=(ans<<3)+(ans<<1)+(c^48); c=getchar();}
return ans*f;
}
ll n, k;
ll a[N];
int q[N], top;
bool vis[N];
namespace force{
int lst[N], top2, cnt;
void dfs(int u, int sum) {
if (u>top2) {vis[sum]=1; return ;}
for (int i=0; i<k; ++i) dfs(u+1, (sum+1ll*lst[u]*i%k)%k);
}
void solve() {
vis[0]=1;
for (int i=1; i<=n; ++i) a[i]=read()%k;
sort(a+1, a+n+1);
for (int i=1; i<=n; ++i) {
if (a[i] && !vis[a[i]]) {
for (int j=1; j<k; ++j) vis[a[i]*j%k]=1;
lst[++top2]=a[i];
}
}
for (int i=0; i<k; ++i) if (vis[i]) ++cnt;
//cout<<"top2: "<<top2<<endl;
if (cnt==k) {
for (int i=0; i<k; ++i) if (vis[i]) q[++top]=i;
printf("%d\n", top);
for (int i=1; i<=top; ++i) printf("%d ", q[i]);
printf("\n");
exit(0);
}
dfs(1, 0);
for (int i=0; i<k; ++i) if (vis[i]) q[++top]=i;
printf("%d\n", top);
for (int i=1; i<=top; ++i) printf("%d ", q[i]);
printf("\n");
exit(0);
}
}
namespace task1{
void solve() {
vis[0]=1;
for (int i=1; i<=n; ++i) a[i]=read()%k;
for (int i=1; i<=n; ++i) {
if (a[i] && !vis[a[i]]) {
for (int j=1; j<k; ++j) vis[a[i]*j%k]=1;
}
}
for (int i=0; i<k; ++i) if (vis[i]) q[++top]=i;
printf("%d\n", top);
for (int i=1; i<=top; ++i) printf("%d ", q[i]);
printf("\n");
exit(0);
}
}
namespace task{
ll gcd(ll a, ll b) {return !b?a:gcd(b, a%b);}
void solve() {
for (int i=1; i<=n; ++i) a[i]=read();
ll t=a[1];
for (int i=2; i<=n; ++i) t=gcd(t, a[i]);
for (int i=0; i<k; ++i) vis[t*i%k]=1;
for (int i=0; i<k; ++i) if (vis[i]) q[++top]=i;
printf("%d\n", top);
for (int i=1; i<=top; ++i) printf("%d ", q[i]);
printf("\n");
exit(0);
}
}
signed main()
{
#ifdef DEBUG
freopen("1.in", "r", stdin);
#endif
n=read(); k=read();
task::solve();
return 0;
}
题解 math的更多相关文章
- 题解 Math teacher's homework
题目传送门 题目大意 给出 \(n,k\) 以及 \(a_{1,2,...,n}\) ,求有多少个 \(m_{1,2,...,n}\) 满足 \(\forall i,m_i\le a_i\) 且 \( ...
- COGS 2188. [HZOI 2015] Math 题解
题目描述: 给定n个数X1-Xn,求下面式子的值(整数部分): n<=107,xi<=109且互不相同. 分析: 其实一开始看见这道题我也吓傻了,k这么大,再说我又是数论鶸渣,打死也不 ...
- DZY Loves Math 系列详细题解
BZOJ 3309: DZY Loves Math I 题意 \(f(n)\) 为 \(n\) 幂指数的最大值. \[ \sum_{i = 1}^{a} \sum_{j = 1}^{b} f(\gcd ...
- 算法题解之math类题
Bulb Switcher 灯泡开关 思路:除了平方数以外,其他所有位置的灯泡最终都被开关了偶数次,因此最终都为0.问题等价于求1~n中平方数的个数. public class Solution { ...
- [CF846B]Math Show题解
暴力一下就好啦! 枚举一下一共做多少次任务,剩下的时间将子任务排序,从头开始能取多少取多少就行了. 贴个代码 #include <cstdio> #include <algorith ...
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- UNR #1 题解
A. 争夺圣杯 还是想说一下,这题是原题啊...想做的人可以戳codechef上的MTMXSUM(懒得贴链接了,套了个壳,不过正常人应该都能看得出来) 显然异或输出没什么奇怪的性质... 考虑一个元素 ...
- toodifficult 题解
名字听起来十分厉害啊...一道lzz的提交答案题. 提答题,我们看看题目,给出一个解密程序,叫你加密. 每个点有一个加密的sample和一些要加密的文本. 从题目中我们可以得到一些信息: 加密后一般为 ...
随机推荐
- Leetcode No.26 Remove Duplicates from Sorted Array(c++实现)
1. 题目 1.1 英文题目 Given an integer array nums sorted in non-decreasing order, remove the duplicates in- ...
- Mybatis代码自动生成(含测试)
一.建立数据库 create database shixun; use shixun; create table user( id int primary key auto_increment , u ...
- Linux | 管首命令符号
简介 管道的意思,在我们日常生活中,意思就是运输一个东西,到下一个地方,所以说 管道命令符 的使用也是差不多的,也是运送一段数据到下一个地方,格式:命令A | 命令B | 命令C .... 所以说,管 ...
- Kubernetes-22:kubelet 驱逐策略详解
为什么要驱逐pod? 在可用计算资源较少时,kubelet为保证节点稳定性,会主动地结束一个或多个pod以回收短缺地资源,这在处理内存和磁盘这种不可压缩资源时,驱逐pod回收资源的策略,显得尤为重要. ...
- 2021最新WordPress安装教程(二):安装PHP和MySQL
这是 2021最新WordPress安装教程系列的第二篇文章,前一篇文章< 2021最新WordPress安装教程(一):Centos7安装Apache>已经完整的介绍了如何在Centos ...
- 软件测试跟踪工具Bugzilla的安装 - Linux版本
首先查看Linux当前版本 输入"uname -a ",可显示电脑以及操作系统的相关信息 输入"cat /proc/version",说明正在运行的内核版本 输 ...
- Vue权限路由实现总结
前言 年前完工了做了半年的铁路后台管理系统,系统整体业务比较复杂,这也是我到公司从 0 到 1 的 一个完整系统实践,做这个系统过程中踩了不少坑,也学到了很多. 做完这个系统没多久,紧接着又一个系统来 ...
- 『与善仁』Appium基础 — 4、常用ADB命令(一)
目录 1.启动和关闭ADB服务 2.查看ADB版本 3.指定adb server的网络端口 4.查询已连接设备/模拟器 5.获取安卓系统版本 6.为命令指定目标设备 7.发送文件到手机 8.从手机拉取 ...
- .net core工具组件系列之Redis—— 第一篇:Windows环境配置Redis(5.x以上版本)以及部署为Windows服务
Cygwin工具编译Redis Redis6.x版本是未编译版本(官方很调皮,所以没办法,咱只好帮他们编译一下了),所以咱们先下载一个Cygwin,用它来对Redis进行编译. Cygwin下载地址: ...
- 扩展中国剩余定理(exCRT)
我 tm--CRT 没看懂 exCRT 却看懂了--emmmm-- 而且这名字完全就是国内的 OI 带师胡起的吧-- 考虑一次同余方程组 \[\begin{cases} x \equiv a_1\ ( ...