在家都变的懒惰了,好久没写题解了,补补CF

模拟 A - Wet Shark and Odd and Even

#include <bits/stdc++.h>

typedef long long ll;
const int N = 1e5 + 5;
const int INF = 0x3f3f3f3f; int main(void) {
std::vector<int> vec;
int n; scanf ("%d", &n);
ll sum = 0;
for (int x, i=1; i<=n; ++i) {
scanf ("%d", &x);
sum += x;
if (x & 1) vec.push_back (x);
}
std::sort (vec.begin (), vec.end ());
int sz = vec.size ();
if (sz > 0 && (sz & 1)) sum -= vec[0];
printf ("%I64d\n", sum); return 0;
}

暴力 B - Wet Shark and Bishops

开始想错了,当成斜率相等的。还好1000范围不大,统计矩阵每条对角线上的个数加点小优化就过了,代码丑。。。

#include <bits/stdc++.h>

typedef long long ll;
const int N = 2e5 + 5;
bool vis[2][1005][1005];
int b[1005][1005];
std::pair<int, int> a[N]; ll cal(int x) {
return 1ll * x * (x - 1) / 2;
}
int get_num1(int x, int y) {
int xx = x, yy = y;
int ret = 0;
while (xx >= 1 && yy >= 1) {
if (b[xx][yy]) ret++, vis[1][xx][yy] = true;
xx--; yy--;
}
xx = x + 1, yy = y + 1;
while (xx <= 1000 && yy <= 1000) {
if (b[xx][yy]) ret++, vis[1][xx][yy] = true;
xx++; yy++;
}
return ret;
} int get_num0(int x, int y) {
int xx = x, yy = y;
int ret = 0;
while (xx <= 1000 && yy >= 1) {
if (b[xx][yy]) ret++, vis[0][xx][yy] = true;
xx++; yy--;
}
xx = x - 1, yy = y + 1;
while (xx >= 1 && yy <= 1000) {
if (b[xx][yy]) ret++, vis[0][xx][yy] = true;
xx--; yy++;
}
return ret;
} int main(void) {
int n; scanf ("%d", &n);
for (int i=0; i<n; ++i) {
scanf ("%d%d", &a[i].first, &a[i].second);
b[a[i].first][a[i].second] = 1;
}
ll ans = 0;
for (int i=0; i<n; ++i) {
int x = a[i].first, y = a[i].second;
if (!vis[0][x][y]) {
ans += cal (get_num0 (x, y));
vis[0][x][y] = true;
}
if (!vis[1][x][y]) {
ans += cal (get_num1 (x, y));
vis[1][x][y] = true;
}
}
printf ("%I64d\n", ans); return 0;
}

期望 C - Wet Shark and Flowers

E = sum (1000 * 乘积是p的倍数的概率)

#include <bits/stdc++.h>

typedef long long ll;
const int N = 1e5 + 5;
const int EPS = 1e-8;
int l[N], r[N];
double pos[N]; int main(void) {
int n, p; scanf ("%d%d", &n, &p);
for (int i=1; i<=n; ++i) {
scanf ("%d%d", &l[i], &r[i]);
pos[i] = 1.0 * (r[i] / p - ((l[i]-1) / p)) / (r[i] - l[i] + 1);
}
l[0] = l[n], r[0] = r[n], pos[0] = pos[n];
double ans = 0;
for (int i=0; i<=n; ++i) {
if (i < n) ans += pos[i] * 1.0 + (1.0 - pos[i]) * pos[i+1];
if (i > 0) ans += pos[i] * 1.0 + (1.0 - pos[i]) * pos[i-1];
}
ans *= 1000;
printf ("%.8f\n", ans); return 0;
}

数学(浮点) D - Rat Kwesh and Cheese

都取log,用long double,精度逆天!powl (): pow的long double版

C语言里对float类型数据的表示范围为-3.4*10^38~+3.4*10^38。double为-1.7*10^-308~1.7*10^308,long double为-1.2*10^-4932~1.2*10^4932.

类型

比特(位)数

有效数字

数值范围

float

32

6~7

-3.4*10^38~+3.4*10^38

double

64

15~16

-1.7*10^-308~1.7*10^308

long double

128/

18~19

-1.2*10^-4932~1.2*10^4932

 

究竟如何计算该范围,分析如下:

对于单精度浮点数(float)来说,符号位一位,指数位8位,尾数23位。指数能够表示的指数范围为-128~127。尾数为23位。

#include <bits/stdc++.h>

std::string ans[12] = {
"x^y^z", "x^z^y", "(x^y)^z", "(x^z)^y", "y^x^z", "y^z^x",
"(y^x)^z", "(y^z)^x", "z^x^y", "z^y^x", "(z^x)^y", "(z^y)^x"
}; typedef long double ldouble;
const double EPS = 1e-10;
ldouble best;
int id; bool better(ldouble val) {
if (fabs (val - best) < EPS) return false;
else if (best < val) {
best = val;
return true;
}
return false;
} void try2(ldouble x, ldouble y, ldouble z, int pos) {
//(x ^ y) ^ z
ldouble val = z * y * log (x);
if (better (val)) id = pos;
} void try1(ldouble x, ldouble y, ldouble z, int pos) {
//x ^ y ^ z
ldouble val = powl (y, z) * log (x);
if (better (val)) id = pos;
} int main(void) {
ldouble x, y, z; std::cin >> x >> y >> z;
best = -1e12; id = -1;
try1 (x, y, z, 0);
try1 (x, z, y, 1);
try2 (x, y, z, 2);
try2 (x, z, y, 3);
try1 (y, x, z, 4);
try1 (y, z, x, 5);
try2 (y, x, z, 6);
try2 (y, z, x, 7);
try1 (z, x, y, 8);
try1 (z, y, x, 9);
try2 (z, x, y, 10);
try2 (z, y, x, 11);
std::cout << ans[id] << '\n'; return 0;
}

数位DP(矩阵快速幂优化) E - Wet Shark and Blocks

题意:b组相同的n个数字,每组选择一个数字合并起来%x == k的方案数。

分析:dp思路,dp[i][(j*10+t)%x] += dp[i-1][j]。但是b太大了选择用矩阵快速幂优化,构造矩阵m[i][j]表示从i到j的方案数,答案就是m[0][k],那么base矩阵就是小于x的某个数字转移到根据给出n个数字转移到另一个数字y的方案数。

UPD:

寒假排位赛出了这题,又不会做。

构造x*x大小的矩阵,m[i][j]表示从i(%x)到j(%x)的方案数,状态转移用矩阵乘法:i->j1,j2,j3...->k => i->k

#include <bits/stdc++.h>
using namespace std; typedef long long ll;
typedef vector<ll> Vec;
typedef vector<Vec> Mat;
const int N = 5e4 + 5;
const int MOD = 1e9 + 7;
int cnt[10];
int n, b, k, x; void add_mod(ll &a, ll b) {
a += b;
if (a >= MOD) a -= MOD;
} Mat matrix_mul(const Mat &A, const Mat &B) {
Mat ret(A.size(), Vec(B[0].size()));
for (int i=0; i<A.size(); ++i)
for (int j=0; j<A[0].size(); ++j) if (A[i][j])
for (int k=0; k<B[0].size(); ++k) if (B[j][k])
add_mod(ret[i][k], A[i][j]*B[j][k]%MOD);
return ret;
} Mat matrix_pow(Mat X, int n) {
Mat ret(X.size(), Vec(X.size()));
for (int i=0; i<X.size(); ++i) ret[i][i] = 1;
for (; n; n>>=1) {
if (n & 1) ret = matrix_mul(ret, X);
X = matrix_mul(X, X);
}
return ret;
} int main() {
scanf("%d%d%d%d", &n, &b, &k, &x);
for (int i=1; i<=n; ++i) {
int d;
scanf("%d", &d);
cnt[d]++;
}
Mat ans(100, Vec(100));
for (int i=0; i<x; ++i) {
for (int j=1; j<=9; ++j) {
ans[i][(i*10+j)%x] += cnt[j];
}
}
ans = matrix_pow(ans, b);
printf("%I64d\n", ans[0][k]);
return 0;
}

  

Codeforces Round #341 (Div. 2)的更多相关文章

  1. Codeforces Round #341 (Div. 2) E. Wet Shark and Blocks dp+矩阵加速

    题目链接: http://codeforces.com/problemset/problem/621/E E. Wet Shark and Blocks time limit per test2 se ...

  2. Codeforces Round #341 (Div. 2) D. Rat Kwesh and Cheese 数学

    D. Rat Kwesh and Cheese 题目连接: http://www.codeforces.com/contest/621/problem/D Description Wet Shark ...

  3. Codeforces Round #341 Div.2 D. Rat Kwesh and Cheese

    嗯本来想着直接算出来不就行了吗 然后我想到了200^200^200....... 好吧其实也不难取两次log就行了 然后我第一次写出来log就写残了........... log里面的拆分要仔细啊.. ...

  4. Codeforces Round #341 Div.2 C. Wet Shark and Flowers

    题意: 不概括了..太长了.. 额第一次做这种问题 算是概率dp吗? 保存前缀项中第一个和最后一个的概率 然后每添加新的一项 就解除前缀和第一项和最后一项的关系 并添加新的一项和保存的两项的关系 这里 ...

  5. Codeforces Round #341 Div.2 B. Wet Shark and Bishops

    题意:处在同一对角线上的主教(是这么翻译没错吧= =)会相互攻击 求互相攻击对数 由于有正负对角线 因此用两个数组分别保存每个主教写的 x-y 和 x+y 然后每个数组中扫描重复数字k ans加上kC ...

  6. Codeforces Round #341 Div.2 A. Wet Shark and Odd and Even

    题意是得到最大的偶数和 解决办法很简单 排个序 取和 如果是奇数就减去最小的奇数 #include <cstdio> #include <cmath> #include < ...

  7. Codeforces Round #341 (Div. 2) ABCDE

    http://www.cnblogs.com/wenruo/p/5176375.html A. Wet Shark and Odd and Even 题意:输入n个数,选择其中任意个数,使和最大且为奇 ...

  8. Codeforces Round #341 (Div. 2) E - Wet Shark and Blocks

    题目大意:有m (m<=1e9) 个相同的块,每个块里边有n个数,每个数的范围是1-9,从每个块里边取出来一个数组成一个数,让你求组成的方案中 被x取模后,值为k的方案数.(1<=k< ...

  9. Codeforces Round #341 (Div. 2) C. Mike and Chocolate Thieves 二分

    C. Mike and Chocolate Thieves time limit per test 2 seconds memory limit per test 256 megabytes inpu ...

随机推荐

  1. osg四元数设置roll pitch heading角度

    roll绕Y轴旋转 pitch绕X轴旋转 heading绕Z轴旋转 单位是弧度,可以使用osg::inDegrees(45)将45角度转换为弧度 定义一个四元数 osg::Quat q( roll,o ...

  2. web前端开发:css3实现loading

    web前端开发:css3实现loading 有大量web前端开发工具及学习资料,可以搜群[ web前端学习部落22群 ]进行下载,遇到学习问题也可以问群内专家以及课程老师哟 <!DOCTYPE ...

  3. hdu 2476 String Painter

    第一道区间dp题,感觉题意不是很好理解 题意:一次可以转换某一个位置的字符,或是一串连续的字符,举第一个例子zzzzzfzzzzz 1:aaaaaaaaaaa 2: abbbbbbbbba 3: ab ...

  4. 三、jQuery--jQuery基础--jQuery基础课程--第11章 jQuery 工具类函数

    1.获取浏览器的名称与版本信息 在jQuery中,通过$.browser对象可以获取浏览器的名称和版本信息,如$.browser.chrome为true,表示当前为Chrome浏览器,$.browse ...

  5. java 接口与继承

    一.继承条件下的构造方法调用 运行 TestInherits.java 示例,观察输出,注意总结父类与子类之间构造方法的调用关系修改Parent构造方法的代码,显式调用GrandParent的另一个构 ...

  6. MVC公开课 – 1.基础 (2013-3-15广州传智MVC公开课)

      1.MVC设计模式 Model 是指 要处理的业务代码和数据操作代码 View 视图 主要是指的 跟用户打交道 并能够展示数据 Controller 看成是 Model和View的桥梁 优点: 1 ...

  7. JavaWeb学习之tomcat安装与运行、tomcat的目录结构、配置tomcat的管理用户、web项目目录、虚拟目录、虚拟主机(1)

    1.tomcat安装与运行双击tomcat目录下的bin/startup.bat,启动之后,输入http://localhost:8080,出现安装成功的提示,表示安装tomcat成功 2.tomca ...

  8. 蛋疼的Fedora17

    在公司给同事要安装ASM oracle 11g,说要在forder17上安装,于是乎我先在自己的虚拟机上安装了一个forder17,遇到了几个很蛋疼的问题:      1. 安装的时候没有创建普通用户 ...

  9. C++ 基础 const放在函数末尾的意思

  10. 修改了/etc/fstab之后出现登录密码输入之后又返回登录界面的问题

    最后那一个挂载到/home下面的盘是我新增加的,如果注释掉就一切正常,如果取消注释,就会发生标题说的问题. 后来我意思都这样直接挂载,导致/home下面原本的东西不在了,注释掉之后再来看,发现下面确实 ...