因为这场比赛,我愉快地逃掉了晚自修。

T1一开始各种SillyB,忘了40%的最低限制。。。

T2各种想吐槽。。。

明明OJ警告说%lld是不行的我就换成%I64D(上面写这样的)。。。

结果各种WA

改成%lld然后不顾警告提交

AC。。。

此时心里:“¥%……#¥……”

后来想了想不是%I64d吗。。。。d是小写的啊。。。。

BC的尿性。。。。

累觉不爱

T3和T4就都不会做啦。。。

于是只能A两道,于是100+的排名,于是Rating也上1500了(噗

代码:

T1

#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cctype>
#include <deque>
#include <cmath>
#define rep(i, l, r) for(int i=l; i<=r; i++)
#define down(i, l, r) for(int i=l; i>=r; i--)
#define clr(x, c) memset(x, c, sizeof(x))
#define travel(x) for(edge *p=fir[x]; p; p=p->n)
#define maxn 50009
#define maxm 300009
#define inf 0x7fffffff
#define ll long long
using namespace std;
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;
} int main()
{
int t=read(), tt=0, a, b, ans; while (tt++<t)
{
ans=0;
a=read(); b=read();
ans+=max(1000*(250-a)/250-b*50, 1000/10*4);
a=read(); b=read();
ans+=max(1500*(250-a)/250-b*50, 1500/10*4);
a=read(); b=read();
ans+=max(2000*(250-a)/250-b*50, 2000/10*4);
a=read(); b=read();
ans+=max(2500*(250-a)/250-b*50, 2500/10*4);
printf("Case #%d: %d\n", tt, ans);
}
return 0;
}

T2

#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cctype>
#define rep(i, l, r) for(int i=l; i<=r; i++)
#define down(i, l, r) for(int i=l; i>=r; i--)
#define maxn 500009
#define Q 998244353
#define ll long long
using namespace std;
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;
}
int n;
ll k[maxn], ans;
bool cmp(ll x, ll y)
{
if (x==y) return true;
while ((x&1)==(y&1)) x>>=1, y>>=1;
return (x&1)==0;
}
void Cal(ll l, ll r, ll v)
{
if (l>=r || v==1073741824) return;
ll mid=l; while (mid<=r && (k[mid]&v)==0) mid++;
ans=(ans+(mid-l)*(r+1-mid)%Q*v%Q)%Q;
Cal(l, mid-1, v<<1); Cal(mid, r, v<<1);
}
int main()
{
int t=read(), tt=0; while (tt++<t)
{
n=read(); ans=0;
rep(i, 1, n) k[i]=read();
sort(k+1, k+1+n, cmp);
Cal(1, n, 1);
printf("Case #%d: %lld\n", tt, ans*2%Q);
}
return 0;
}

题解:

1001 ZYB loves Score
本题考察了选手的模拟能力,直接按照题目意思计算即可

1002 ZYB loves Xor I
我们考虑,当A xor B的答案为2p时,A和B表示成二进制数后末p−1位肯定相同
于是我们维护一颗字母树,将每个数表示成二进制数后翻转可以下,插入字母树
统计答案时,我们找出Ai的二进制数翻转后在字母树上的路径,对于路径上每个点x,设他走的边是v,且当前为第k位,则和他xor后lowbit为2k的数的个数为trans(x,v^1)的子树大小。
trans(x,v)表示字母树上在结点x,走连出去的字母为v的边到达的结点
时间复杂度:O(nlogA)

1003 ZYB loves Xor II
我们考虑两个数A,B。
为了描述方便,我们设[P]的值为:当表达式P的值为真时,[P]=1,否则[P]=0
我们现在考虑计算[(A+B)and(2i)>0]
首先我们将A,B都对2i+1取模,显然这样是不会影响答案的
则有一个十分显然的等式:
[(A+B)and(2i)>0]=[(A+B)≥(2i)]−[(A+B)≥(2i+1)]+[(A+B)≥(3∗2i)]
这个式子相当容易理解,这里不多述了
考虑每一位对答案的贡献是独立的,我们每一位分开做
于是现在问题变成了:给定数组A,B,求满足Ai+Bj≥limit的数对个数
我们可以将A,B排序后,直接O(n)计算即可
然而排序是O(nlogn)的,这样总复杂度就是O(nlognlogA)了,无法通过此题
于是这里有个小技巧
我们从高位往低位做,现在我们要实现的是:将A中每个数对P取模后将A排序
我们发现A会被分成两段,一段小于P,一段大于等于P,只有后面一段要取模,我们可以取模后直接将这两段归并,复杂度是O(n)的
时间复杂度:O(nlogA+nlogn)

1004 ZYB loves product
个人感觉这题没有上一题难
首先我们考虑DP思路,设f[k][n]为n的k分解的权值和
则有f[k][n]=∑d|nf[k−1][d]∗V(nd)
我们可以发现上述DP方程是个狄利克雷卷积的形式
然后我们可以发现权值函数V(x)是积性函数
所以易得f[k]也是个积性函数
于是我们把n质因数分解
现在把n的规模变成了ap
设g[k][p]=f[k][ap]
设h[p]=V(ap)
于是我们可以得到转移方程g[k][n]=∑ni=0g[k−1][i]∗h[n−i]
这是个卷积形式,我们可以用倍增+FFT计算g
时间复杂度:O(fplog(p)log(m))

【BestCoder #44】的更多相关文章

  1. 1344:【例4-4】最小花费 dijkstra

    1344:[例4-4]最小花费 Dijkstra (1)a [ i ] [ j ] 存转账率(..转后所得率..) (2)dis [ i ] 也就是 a [ 起点 ] [ i ] (3)f [ i ] ...

  2. 【BestCoder】【Round#44】

    模拟+Trie+桶排(归并?)+容斥 A 模(shou)拟(su)题= =感觉好像见过? 计算得分什么的…… //BestCoder #44 A #include<vector> #inc ...

  3. 【BestCoder #48】

    与之前一样,秒刷A和B,然后就永远卡在了C B也因为少看一句话被Hunt掉了 说说C的做法吧(分块大法好 给定一个序列,每次询问区间l-r,求∑(ai^bi),其中bi是指ai在区间中的出现次数,ai ...

  4. 【BestCoder #45】

    用家里的电脑来编程,各种不算 一开始15分钟刷掉T1和T2,然后就永远地卡在了T3... 后来看题解,傻了眼... 它强调的“只有一个答案”我还以为这是在提示我二分答案,于是我一直往权值线段树那个方向 ...

  5. 【C语言】printf()函数详解

    printf函数称为格式输出函数,其关键字最末一个字母f即为"格式"(format)之意.其功能是按用户指定的格式,把指定的数据显示到显示器屏幕上.在前面的例题中我们已多次使用过这 ...

  6. PYOJ 44. 【HNSDFZ2016 #6】可持久化线段树

    #44. [HNSDFZ2016 #6]可持久化线段树 统计 描述 提交 自定义测试 题目描述 现有一序列 AA.您需要写一棵可持久化线段树,以实现如下操作: A v p x:对于版本v的序列,给 A ...

  7. 【BestCoder】【Round#41】

    枚举+组合数?+DP+数学问题 http://bestcoder.hdu.edu.cn/contests/contest_show.php?cid=582 QAQ许久没打过比赛,来一发BC,结果还是只 ...

  8. 【j2ee spring】44、巴巴运动网前台产品显示

    [j2ee spring]44.巴巴运动网前台产品显示 项目结构 项目代码 界面显示 <%@ page language="java" isELIgnored="f ...

  9. JAVA 基础编程练习题44 【程序 44 偶数的素数和】

    44 [程序 44 偶数的素数和] 题目:一个偶数总能表示为两个素数之和. package cskaoyan; public class cskaoyan44 { @org.junit.Test pu ...

随机推荐

  1. java基础 静态 static 问在多态中,子类静态方法覆盖父类静态方法时,父类引用调用的是哪个方法?

    多态 package com.swift.jiekou; public class Jicheng_Tuotai_jingtai_diaoyong { public static void main( ...

  2. java基础必备单词讲解 day three

    if 如果 else 否则 switch 切换判断 case 实例 break 退出 return 返回 default 默认 variable array 数组 null 空的 无效的 pointe ...

  3. socket上传nsdictionary的json数据异常

    异常情况如下:按照正常的写法,将上传对数据封装在nsdictionary里,然后检验是否符合json格式化,调用系统的json序列化方法将nsdictionary转化为json数据然后上传, 异常结果 ...

  4. 给大家一个我的QQ群

    很少关注博客了,提供一个QQ群讨论 我的一个QQ群:158351344

  5. MySQL主从复制读写分离如何提高从库性能-实战

    在做主从读写分离时候,需要注意主从的一些不同参数设置,来提高从库的性能,提高应用读取数据的速度,这样做很有必要的. 做读写分离复制主从参数不同设置如下(需要根据自己应用实际情况来设置): parmet ...

  6. redis操作帮助类

    RedisHelper.java import redis.clients.jedis.*; import java.util.*; public class RedisHelper { privat ...

  7. dede后台添加优酷等视频iframe链接时被替换成了图片

     添加文章时 添加优酷视频 :<iframe height=498 width=510 src='http://player.youku.com/embed/XNDAzNTAzODE4OA==' ...

  8. Servlet异步处理和文件上传

    1. 什么是异步处理     原来,在服务器没有结束响应之前,浏览器是看不到响应内容的!只有响应结束时,浏览器才能显示结果!     现在异步处理的作用:在服务器开始响应后,浏览器就可以看到响应内容, ...

  9. PLC状态机编程-如何在STL中使用状态机

    搞PLC编程多年,一直不知道状态机,学习matlab后,发现状态机编程异常方便,过去很多编程时的疑惑豁然开朗起来.今天跟大家分享一下如何在STL中使用状态机. 下面是用状态机描述的控制任务. 这个状态 ...

  10. Python学习笔记:json模块和pickle模块(数据序列化)

    Python中的json模块和pickle都是用于数据的序列化和反序列化,它们提供的方法也是一样的:dumps,dump,loads,load dumps(obj):将对象序列化为str. dump( ...