也许是最后一篇了。

A.最大或

不错的签到题。

对于二进制位来说,高位的一个1比低位的所有1的贡献总和还要大。

显然,$r$必选,因为$r$中所有1的相对考前。那么考虑如何构造另一个数。

首先$l$和$r$前几位相同的部分肯定是不能动的,所以从$l,r$不同那位开始贪心即可。如果$r$这位为0,只要构造的这个数爆不了$r$就让它的这位为1。

#include<cstdio>
#include<cstring>
#include<iostream>
#include<cmath>
using namespace std;
typedef long long ll;
int T;
ll l,r;
void work()
{
scanf("%lld%lld",&l,&r);
ll res=0;bool ok=0;
for(int i=62;i>=0;i--)
{
int now=(r>>i)&1LL,nowl=(l>>i)&1LL;
if(now!=nowl)ok=1;
//cout<<i<<' '<<now<<' '<<nowl<<' '<<ok<<endl;
if(!now)
if((res|(1LL<<i))<=r&&ok)res|=1LL<<i;
}
printf("%lld\n",r|res);
}
int main()
{
freopen("maxor.in","r",stdin);
freopen("maxor.out","w",stdout);
scanf("%d",&T);
while(T--)work();
return 0;
}

B.答题

题意可以转化为:求用所给的$n$个数组成的$2^n$个数中的第$k$大值,$k=ceil(2^n \times p)$。

然后就是裸的折半搜索了。分别搜出前一半和后一半的子集和,然后二分答案。

之后考虑如何求 从两组数里各取一个数,且令取出的两数和$\ge$二分值的数对的个数。

先把两组数排序,然后枚举第一组选到哪个,第二组维护一个倒着扫的单调指针即可。

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int n,a[45],n1,n2,sz1,sz2;
double p;
ll kth;
vector<int>s1,s2;
void dfs(int x,int tot,int op)
{
if(!op&&x>n1)
{ s1.push_back(tot);
return ;
}
if(op&&x>n)
{
s2.push_back(tot);
return ;
}
dfs(x+1,tot,op);
dfs(x+1,tot+a[x],op);
}
bool check(int val)
{
ll res=0;int j=sz2;
for(int i=0;i<sz1;i++)
{
res+=sz2-j;
while(j>0&&s2[j-1]+s1[i]>=val)j--,res++;
}
return res>=kth;
}
#define F
int main()
{
#ifdef F
freopen("answer.in","r",stdin);
freopen("answer.out","w",stdout);
#endif
scanf("%d%lf",&n,&p);
for(int i=1;i<=n;i++)
scanf("%d",&a[i]);
kth=(1LL<<n)-ceil(1.0*(1LL<<n)*p)+1;
n1=n/2;
dfs(1,0,0);dfs(n1+1,0,1);
sz1=s1.size();sz2=s2.size();
sort(s1.begin(),s1.end());
sort(s2.begin(),s2.end());
int l=0,r=1e9,ans;
while(l<=r)
{
int mid=l+r>>1;
if(check(mid))ans=mid,l=mid+1;
else r=mid-1;
}
cout<<ans<<endl;
return 0;
}

C.联合权值·改

其实正解挺神的……但是它w范围这么小 不用白不用啊。

直接开桶维护每个联合权值的个数,然后利用bitset去除三元环的情况即可。

我没脸

#include<cstdio>
#include<iostream>
#include<cstring>
#include<bitset>
using namespace std;
#define pa pair<int,int>
#define re register
inline int read()
{
int x=0,f=1;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}
while(isdigit(ch))x=x*10+ch-'0',ch=getchar();
return x*f;
}
typedef long long ll;
const int N=3e4+5;
int n,m,t;
int to[N<<1],head[N],nxt[N<<1],tot,ansm;
pa p[N<<1];
bitset<N> s[N];
ll w[N],anss,bu[N>>1],cnt[N>>1];
inline void add(re int x,re int y)
{
to[++tot]=y;
nxt[tot]=head[x];
head[x]=tot;
}
inline void print()
{
if(t!=2)printf("%d\n",ansm);
else puts("0");
if(t!=1)printf("%lld\n",anss);
else puts("0");
}
#define F
int main()
{
#ifdef F
freopen("link.in","r",stdin);
freopen("link.out","w",stdout);
#endif
n=read();m=read();t=read();
for(re int i=1;i<=m;i++)
{
int x=read(),y=read();
p[i]=make_pair(x,y);
add(x,y);add(y,x);s[x][y]=1;s[y][x]=1;
}
for(re int i=1;i<=n;i++)
w[i]=read();
for(re int x=1;x<=n;x++)
{
memset(bu,0,sizeof(bu));
for(re int i=head[x];i;i=nxt[i])
{
int y=to[i];
for(int k=1;k<=100;k++)
cnt[w[y]*k]+=bu[k];
bu[w[y]]++;
}
}
for(int i=1;i<=m;i++)
{
int now=(s[p[i].first]&s[p[i].second]).count();//cout<<i<<' '<<now<<endl;
cnt[w[p[i].first]*w[p[i].second]]-=now;
}
for(int i=1;i<=10000;i++)
anss+=1LL*i*cnt[i],ansm=max(ansm,cnt[i]?i:0);
anss*=2;
print();
return 0;
}

[CSP-S模拟测试110]题解的更多相关文章

  1. CSP-S 模拟测试94题解

    T1 yuuustu: 可以对两边取对数,然后就转化为两个double的比较,时间复杂度$O(n)$ 然后我就用神奇0.4骗分水过 #include<bits/stdc++.h> usin ...

  2. CSP-S模拟测试 88 题解

    T1 queue: 考场写出dp柿子后觉得很斜率优化,然后因为理解错了题觉得斜率优化完全不可做,只打了暴力. 实际上他是可以乱序的,所以直接sort,正确性比较显然,贪心可证,然后就是个sb斜率优化d ...

  3. CSP-S 模拟测试92 题解

    话说我怎么觉得我没咕多长时间啊,怎么就又落了20多场题解啊 T1 array: 根据题意不难列出二元一次方程,于是可以用exgcd求解,然而还有一个限制条件就是$abs(x)+abs(y)$最小,这好 ...

  4. CSP-S 模拟测试57题解

    人生第一次A,B层一块考rank2,虽然说分差没几分,但还是值得纪念. 题解: T1 天空龙: 大神题,因为我从不写快读也没有写考场注释的习惯,所以不会做,全hzoi就kx会做,kx真大神级人物. T ...

  5. CSP-S 模拟测试 51 题解

    考试过程: 惯例先看一遍三道题,T1 一开始反应要求割点,但是这是有向图,肯定不能求割点,康了一下数据范围,有40%是树的,还不错,决定待会在打. 看T2 字符串题,完了我字符串最弱了,肯定只能打暴力 ...

  6. CSP-S 模拟测试 45 题解

    由于咕掉的题解太多了,所以只能趁改完不动题的时间,来补补坑qwq,还是太弱了. 考试过程: 到新机房的第一次考试,貌似海星? 第一题一开始就觉得是个贪心,但以为所有小怪兽都要打完,所以想复杂了,但后来 ...

  7. [CSP-S模拟测试97]题解

    A.小盆友的游戏 感觉题解解释的很牵强啊……还是打表找规律比较靠谱 对于每个人,它构造了一个期望函数$f(x)$,设它的跟班个数为$cnt[x]$,那么令$f(x)=2^{cnt[x]}-1$(??鬼 ...

  8. [CSP-S模拟测试96]题解

    以后不能再借没改完题的理由不写题解了…… A.求和 求$\sum \sum i+j-1$ 柿子就不化了吧……这年头pj都不考这么弱智的公式化简了…… 坑点1:模数不定,可能没有2的逆元,那么只要先把乘 ...

  9. [CSP-S模拟测试92]题解

    A.数列 显然每个数的答案是互相独立的,直接扩欧求解.我们需要最小化$ax+by=gcd(a,b)$中的$|x|+|y|$,而显然当x或y靠近0时答案可能最优,列个不等式求一下即可. 能$O(1)$千 ...

随机推荐

  1. 修改JAVA_HOME失效

    在修改JDK的安装目录的情况下会出现失效的时候,因为jdk在安装的时候自己在path中添加了 C:\ProgramData\Oracle\Java\javapath 这个路径. 解决: 删除 path ...

  2. python基础数据类型补充以及编码的进阶

    一.基本数据类型的补充循环列表改变列表大小的问题#请把列表中索引为基数的元素写出l1=[1,2,3,4,5,6]for i in l1: if i%2!=0: print(i)结果:135二:基本数据 ...

  3. Tensorflow实战(二):Discuz验证码识别

    一.前言 验证码是根据随机字符生成一幅图片,然后在图片中加入干扰象素,用户必须手动填入,防止有人利用机器人自动批量注册.灌水.发垃圾广告等等 . 验证码的作用是验证用户是真人还是机器人. 本文将使用深 ...

  4. mooc-IDEA 项目/文件之间跳转--002

    二.IntelliJ IDEA -项目之间跳转 1.Next Project Window :跳转到下一个项目 [ ctrl+alt+) ] 2.Previous Project Window:跳转到 ...

  5. [LeetCode]29 两数相除和一个小坑点

    给定两个整数,被除数 dividend 和除数 divisor.将两数相除,要求不使用乘法.除法和 mod 运算符. 返回被除数 dividend 除以除数 divisor 得到的商. 示例 1: 输 ...

  6. oracle--groupby分组学习

    使用group by分组 在多行函数中不能直接使用普通字段,除非group by 在多行函数中不能直接使用单行函数,除非group by group by学习: ---1.使用group by进行数据 ...

  7. [常用类]StringBuffer 类,以及 StringBuilder 类

    线程安全,可变的字符序列. 字符串缓冲区就像一个String ,但可以修改. 在任何时间点,它包含一些特定的字符序列,但可以通过某些方法调用来更改序列的长度和内容. 字符串缓冲区可以安全地被多个线程使 ...

  8. HDUSTOJ-1558 Flooring Tiles(反素数)

    1558: Flooring Tiles 时间限制: 3 Sec  内存限制: 128 MB提交: 59  解决: 36[提交][状态][讨论版] 题目描述 You want to decorate ...

  9. [Java] 歐付寶金流串接教學

    前言: 很多接案的人,都會碰到需要接金流的時候.而歐付寶是個台灣的金流平台. 這邊記錄下,串接的心得.我用的語言是Java, 採liferay這個portal平台,不過這份教學當然適合servlet. ...

  10. SCUT - 77 - 哈利波特与他的魔法杖

    https://scut.online/p/77 METO说是单点更新线段树.要记录哪些点不用再更新,不太清楚具体是要怎么实现? 一个类似的想法是把n个点建一棵平衡树,每次节点变成0之后从树上移除,至 ...