CF895C: Square Subsets && 【BZOJ2844】albus就是要第一个出场

这两道题很类似,都是线性基的计数问题,解题的核心思想也一样。

CF895C Square Subsets

题目链接

题意

给定\(n\)个数,求多少种选数方案使得选出来的数乘积为完全平方数。\(n\leq 100000,a_i\leq70\)。

完全平方数的本质就是每个质因子的次数为偶数。

所以我们将每一个数唯一分解,然后记录每个质因子的奇偶状态,就得到了一个个01串。问题就变成了有多少个集合中的数异或为0。

我们建好线性基,设线性基的秩为\(m\),则答案就是\(2^{n-m}-1\)。再判线性基能否组成0,如果能,答案再\(+1\)

因为线性基中的\(m\)个元素是线性无关的,并且可以表达出其他数的所有线性组合,所以其他\(2^{n-m}-1\)(减掉都不选的一种情况)的所有数都能在线性基中找到唯一的一个组合与之异或起来为0。

代码:

#include<bits/stdc++.h>
#define ll long long using namespace std; int n;
ll p[50],cnt;
bool Insert(ll x) {
for(int i=20;i>=0;i--) {
if(!(x>>i)&1) continue ;
if(!p[i]) return p[i]=x,1;
x^=p[i];
}
return 0;
}
ll pri[100];
bool vis[100];
void pre() {
for(int i=2;i<=70;i++) {
if(!vis[i]) pri[++pri[0]]=i;
for(int j=1;j<=pri[0]&&i*pri[j]<=70;j++) {
vis[i*pri[j]]=1;
if(i%pri[j]==0) break;
}
}
}
void break_down(ll v) {
ll x=0;
for(int i=1;i<=pri[0];i++) {
while(v%pri[i]==0) {
x^=1<<i;
v/=pri[i];
}
}
if(!Insert(x)) cnt++;
}
int main() {
pre();
scanf("%d",&n);
ll a;
for(int i=1;i<=n;i++) {
scanf("%lld",&a);
break_down(a);
}
ll t=2,ans=1;
for(;cnt;cnt>>=1,t=t*t%1000000007) {
if(cnt&1)ans=ans*t%1000000007;
}
cout<<(ans-1+1000000007)%1000000007;
return 0;
}

【BZOJ2844】albus就是要第一个出场

题目链接

我们就是要求比\(Q\)小的集合有多少个。

和上一道题一样,我们就是要求比\(Q\)小,且能被线性基表示出来的数有多少个,我们设为\(lower\),则答案为\(lower\cdot 2^{n-m}+1\)。

问题其实就是求\(\leq Q-1\)的的最大的数的\(Rank\)。

我的实现方式不太一样。我们就找\(\leq Q-1\)的数的数量。\(\leq Q-1\)一定是从高到低的前\(i-1\)位相同,第\(i\)位小一些,后面的几位随便。于是我们就考虑\(Q\)的前\(i\)位,我们设为\(Q'\),然后将所有数的前\(i\)位建线性基。问题就变成求有多少种方法能组合出\(Q'\)。

这样做复杂度要比网上的一般写法多一个\(log\),不过个人感觉好理解些。

代码:

#include<bits/stdc++.h>
#define ll long long
#define N 100005
#define mod 10086 using namespace std;
inline int Get() {int x=0,f=1;char ch=getchar();while(ch<'0'||ch>'9') {if(ch=='-') f=-1;ch=getchar();}while('0'<=ch&&ch<='9') {x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}return x*f;} int n;
int p[35],a[N];
int Q;
bool Insert(int a) {
for(int i=30;i>=0;i--) {
if(a&(1<<i)) {
if(!p[i]) return p[i]=a,1;
else a^=p[i];
}
}
return 0;
}
int cnt;
void build(int k) {
cnt=0;
memset(p,0,sizeof(p));
for(int i=1;i<=n;i++) {
cnt+=Insert(a[i]>>k);
}
}
ll ans;
ll pw[N]; int main() {
n=Get();
pw[0]=1;
for(int i=1;i<=n;i++) pw[i]=(pw[i-1]<<1)%mod;
for(int i=1;i<=n;i++) a[i]=Get();
Q=Get();
for(int i=30;i>=0;i--) {
if(Q&(1<<i)) {
build(i);
if(!Insert((Q>>i)^1)) {
(ans+=pw[n-cnt])%=mod;
}
}
}
cout<<(ans+1)%mod;
return 0;
}

CF895C: Square Subsets && 【BZOJ2844】albus就是要第一个出场的更多相关文章

  1. BZOJ2844: albus就是要第一个出场

    Description 已知一个长度为n的正整数序列A(下标从1开始), 令 S = { x | 1 <= x <= n }, S 的幂集2^S定义为S 所有子集构成的集合. 定义映射 f ...

  2. BZOJ2844: albus就是要第一个出场(线性基)

    Time Limit: 6 Sec  Memory Limit: 128 MBSubmit: 2054  Solved: 850[Submit][Status][Discuss] Descriptio ...

  3. bzoj千题计划195:bzoj2844: albus就是要第一个出场

    http://www.lydsy.com/JudgeOnline/problem.php?id=2844 题意:给定 n个数,把它的所有子集(可以为空)的异或值从小到大排序得到序列 B,请问 Q 在  ...

  4. 【贪心】【线性基】bzoj2844 albus就是要第一个出场

    引用题解:http://blog.csdn.net/PoPoQQQ/article/details/39829237 注意评论区. #include<cstdio> using names ...

  5. 【线性基】bzoj2844: albus就是要第一个出场

    线性基求可重rank 题目描述 给定 n 个数 $\{ a_i \}$ ,以及数 $x$. 将 $\{ a_i \}$​ 的所有子集(包括空集)的异或值从小到大排序,得到 $\{ b_i \} $. ...

  6. 【BZOJ2844】albus就是要第一个出场 高斯消元求线性基

    [BZOJ2844]albus就是要第一个出场 Description 已知一个长度为n的正整数序列A(下标从1开始), 令 S = { x | 1 <= x <= n }, S 的幂集2 ...

  7. BZOJ 2844: albus就是要第一个出场 [高斯消元XOR 线性基]

    2844: albus就是要第一个出场 题意:给定一个n个数的集合S和一个数x,求x在S的$2^n$个子集从小到大的异或和序列中最早出现的位置 一开始看错题了...人家要求的是x第一次出现位置不是第x ...

  8. BZOJ 2844: albus就是要第一个出场

    2844: albus就是要第一个出场 Time Limit: 6 Sec  Memory Limit: 128 MBSubmit: 1134  Solved: 481[Submit][Status] ...

  9. 2844: albus就是要第一个出场

    2844: albus就是要第一个出场 链接 分析: 和HDU3949差不多互逆,这里需要加上相同的数. 结论:所有数任意异或,构成的数出现一样的次数,次数为$2^{n-cnt}$,cnt为线性基的大 ...

随机推荐

  1. window7环境下ZooKeeper的安装运行及监控查看

    原文:http://www.cnblogs.com/RainAndWind/p/4668427.html ZooKeeper是一个分布式开源框架,供了协调分布式应用的基本服务.这些天在使用DUBBO, ...

  2. show profiles 分析sql耗时瓶颈

    1.首先查看是否开启profiling功能 SHOW VARIABLES LIKE '%pro%'; 或者 SELECT @@profiling; 2.开启profiling ; 3.执行sql语句例 ...

  3. 解决springmvc中使用redirect跳转后https变为http

    方法一:配置文件修改ViewResolver的 redirectHttp10Compatible 属性,这个属性是为了兼容 http1.0协议. <bean id="viewResol ...

  4. 如何调试Javascript代码以及网页代码

    做过网页开发的都知道,不过你是用php还是asp.net以及java开发的网站,在开发过程中,web网页展示页面肯定会出现或多或少的问题.这里我推荐使用谷歌浏览器进行Web网页的调试以及错误信息定位. ...

  5. 设计模式之策略模式(Strategy)

    策略模式将不同算法的逻辑抽象接口封装到一个类中,通过组合和多态结合的方式来进行不同算法具体的实现. 作用 策略模式是一种定义一系列算法的方法,Strategy类层次为Context定义了一系列的可重用 ...

  6. 26个精选的JavaScript面试问题

    译者按: 从各个平台精选整理出26道由浅入深的题目助你面试 原文: Top 26 JavaScript Interview Questions I Wish I Knew 译者: Fundebug 为 ...

  7. git命令详解( 二 )

    这是git详解的第二篇,最近这个加班有点虚,所以文章也写的比较懒了,一到加班不得已,保温杯里泡枸杞啊,不扯了,今天我们来看看git的第二篇 这篇内容主要是git的一些远程命令 远程仓库 git clo ...

  8. CoreCRM 开发实录 —— 基于 AntDesign 的新 UI

    上一篇说到,因为有新朋友加入,对前端开发有了新的要求.原来基于 Bootstrap 的 UI 就不要了.在网上(其实是 GitHub 上)逛了几圈,最后使用了 antd-admin 这个框架做为基础模 ...

  9. [VUE ERROR] Duplicate keys detected: 'tab-user'. This may cause an update error.

    错误消息如图: 如果你看到此错误消息,则说明 v-for 指令的 key值 重复了,只需修改你的 key值 让其不会重复即可.

  10. [ng:areq] Argument 'XXXXCtrl' is not a function, got undefined

    angular.module('MyApp', []) 这里的[]重复了,以后引入新的controller.js文件会覆盖前面那个,所以此处的[]去掉 .controller('MyCtrl', fu ...