A. Definite Game

签.

 #include <bits/stdc++.h>
using namespace std; int main()
{
int a;
while (scanf("%d", &a) != EOF)
{
[](int x)
{
for (int i = x - ; i >= ; --i) if (x % i)
{
printf("%d\n", x - i);
return;
}
printf("%d\n", x);
}(a);
}
return ;
}

B. Farewell Party

签。

 #include <bits/stdc++.h>
using namespace std; #define N 100010
int n, a[N], b[N], cnt[N];
vector <int> v[N];
int ans[N]; bool ok()
{
for (int i = ; i <= n; ++i) if (!v[i].empty() && v[i].size() != i)
return false;
return true;
}
void solve()
{
int cnt = ;
for (int i = ; i <= n; ++i) v[i].clear();
for (int i = ; i <= n; ++i)
{
int id = n - a[i];
if (v[id].size() == id)
{
++cnt;
for (auto it : v[id]) ans[it] = cnt;
v[id].clear();
}
v[id].push_back(i);
}
if (!ok())
{
puts("Impossible");
return;
}
else
{
for (int i = ; i <= n; ++i) if (!v[i].empty())
{
++cnt;
for (auto it : v[i])
ans[it] = cnt;
}
puts("Possible");
for (int i = ; i <= n; ++i) printf("%d%c", ans[i], " \n"[i == n]);
}
} int main()
{
while (scanf("%d", &n) != EOF)
{
for (int i = ; i <= n; ++i) scanf("%d", a + i);
solve();
}
return ;
}

C. Colorful Bricks

Upsolved.

题意:

有$一行n个方格,m种颜色,恰好有k个方块与它左边方块的颜色不同$

求方案数

思路:

$dp[i][j] 表示到第i个方格,有j个方块与左边方块颜色不同的方案数$

转移有

$dp[i + 1][j] += dp[i][j]$

$dp[i + 1][j + 1] += dp[i][j] * (m - 1)$

 #include <bits/stdc++.h>
using namespace std; #define ll long long
#define N 2010
const ll MOD = (ll);
int n, m, k;
ll f[N][N]; int main()
{
while (scanf("%d%d%d", &n, &m, &k) != EOF)
{
memset(f, , sizeof f);
f[][] = m;
for (int i = ; i <= n; ++i)
{
for (int j = ; j <= min(i - , k); ++j)
{
f[i][j] = (f[i][j] + f[i - ][j]) % MOD;
f[i][j + ] = (f[i][j + ] + f[i - ][j] * (m - ) % MOD) % MOD;
}
}
printf("%lld\n", f[n][k]);
}
return ;
}

D. Maximum Distance

Upsolved.

题意:

有一张图

定义一条路径的长度的路径上边权最大值

定义两点距离为两点之间最短路径

有一些特殊点,要对所有特殊点求离它最远的特殊点

思路:

我们考虑一条边所连接的两个连通块里,如果这两个连通块里都有特殊点

那么这条边的权值就可以用于更新特殊点的答案

其实就是一个求最小生成树的过程,先按边权排序

要注意的是不是求整个图的最小生成树,而是所有特殊点的最小生成树

其实是最小瓶颈生成树.

 #include <bits/stdc++.h>
using namespace std; #define N 100010
int n, m, k;
struct node
{
int u, v, w;
void scan() { scanf("%d%d%d", &u, &v, &w); }
bool operator < (const node &other) const { return w < other.w; }
}edge[N]; int pre[N], cnt[N];
int find(int x) { return pre[x] == ? x : pre[x] = find(pre[x]); }
int Kruskal()
{
sort(edge + , edge + + m);
for (int i = ; i <= m; ++i)
{
int u = edge[i].u, v = edge[i].v, w = edge[i].w;
int fu = find(u), fv = find(v);
if (fu == fv) continue;
cnt[fv] += cnt[fu];
pre[fu] = fv;
if (cnt[fv] == k) return w;
}
} int main()
{
while (scanf("%d%d%d", &n, &m, &k) != EOF)
{
memset(pre, , sizeof pre);
memset(cnt, , sizeof cnt);
for (int i = , x; i <= k; ++i) scanf("%d", &x), cnt[x] = ;
for (int i = ; i <= m; ++i) edge[i].scan();
int res = Kruskal();
for (int i = ; i <= k; ++i) printf("%d%c", res, " \n"[i == k]);
}
return ;
}

E. Missing Numbers

Upsolved.

题意:

有$n个数,给出a_2, a_4 \cdots a_n$

$n是偶数,提供a_1, a_3 \cdots a_{n - 1}$

使得

$所有前缀和都是平方数$

思路:

考虑$n = 2的时候$

$我们令b^2 = a_1 + a_2$

$a^2 = a_1$

那么有

$b^2 - a^2 = (b + a) \cdot (b - a) = a_2$

$我们将a_2 拆成 p \cdot q 的形式$

$令p >= q$

$那么有  b + a = p, b - a = q$

$解方程有 b = \frac{p + q}{2}$

$发现一限制条件 p, q的奇偶性要相同$

$那么a_1 = (\frac{p + q}{2})^2 - a_2$

那么如果有多解 我们取$a_1最小的$

$因为当n >= 2的情况也可以同样这样推下去,会发现前面的项越小越好$

 #include <bits/stdc++.h>
using namespace std; #define ll long long
#define N 100010
int n;
ll x[N];
vector <int> vec[N << ]; void init()
{
for (int i = ; i <= ; ++i)
for (int j = i * i; j <= ; j += i)
vec[j].push_back(i);
} int main()
{
init();
while (scanf("%d", &n) != EOF)
{
for (int i = ; i <= n; i += ) scanf("%lld", x + i);
bool flag = true;
ll base = ;
for (int i = ; i <= n; i += )
{
base += x[i + ];
int limit = sqrt(x[i + ]);
ll res = (ll)1e18;
ll p, q;
for (auto j : vec[x[i + ]])
if ((j % ) == ((x[i + ] / j) % ))
{
p = j, q = (x[i + ] / j);
ll tot = (p + q) / ;
tot *= tot;
if (tot > base)
res = min(res, tot - base);
}
if (res <= (ll)1e13)
{
x[i] = res;
base += res;
}
else
{
flag = false;
break;
}
}
if (!flag) puts("No");
else
{
puts("Yes");
for (int i = ; i <= n; ++i)
printf("%lld%c", x[i], " \n"[i == n]);
}
}
return ;
}

Avito Cool Challenge 2018 Solution的更多相关文章

  1. Codeforces Avito Code Challenge 2018 D. Bookshelves

    Codeforces Avito Code Challenge 2018 D. Bookshelves 题目连接: http://codeforces.com/contest/981/problem/ ...

  2. Avito Cool Challenge 2018 B. Farewell Party 【YY】

    传送门:http://codeforces.com/contest/1081/problem/B B. Farewell Party time limit per test 1 second memo ...

  3. Avito Cool Challenge 2018

    考挂了.. A - Definite Game 直接看代码吧. #include<cstdio> #include<cstring> #include<algorithm ...

  4. Avito Cool Challenge 2018(div1+2)

    A. Definite Game: 题意:输入N,输出最小的结果N-x,其中x不少N的因子. 思路:N=2时,输出2:其他情况输出1:因为N>2时,N-1不会是N的因子. #include< ...

  5. Avito Code Challenge 2018

    第一次打CF,很菜,A了三道水题,第四题好像是是数位DP,直接放弃了.rateing从初始的1500变成了1499,还是绿名,这就很尴尬.之后觉得后面的题目也没有想象的那么难(看通过人数)过两天吧剩下 ...

  6. Avito Cool Challenge 2018 自闭记

    A:n==2?2:1. #include<iostream> #include<cstdio> #include<cmath> #include<cstdli ...

  7. Avito Cool Challenge 2018 E. Missing Numbers 【枚举】

    传送门:http://codeforces.com/contest/1081/problem/E E. Missing Numbers time limit per test 2 seconds me ...

  8. Avito Cool Challenge 2018 C. Colorful Bricks 【排列组合】

    传送门:http://codeforces.com/contest/1081/problem/C C. Colorful Bricks time limit per test 2 seconds me ...

  9. Avito Cool Challenge 2018:D. Maximum Distance (最小生成树)

    题目链接 题意 : 给出一个联通图和一些特殊的点,现在定义cost(u,v)为一条从u到v的路径上面边权的最大值 , 定义dis(u,v) 为从u到v 路径上面cost 的最小值 然后求所有特殊点到其 ...

随机推荐

  1. 服务器允许js跨域

    header('Access-Control-Allow-Origin:*'); header('Access-Control-Allow-Methods:POST,GET'); header('Ac ...

  2. Qt监控后台服务运行状态

    mainwindow.h #ifndef MAINWINDOW_H #define MAINWINDOW_H #include <QMainWindow> #include <QMa ...

  3. linux系统usb挂载

    本次例程的环境是在FC6下,通过终端操作的. 注意要挂载U盘需要有管理员的权限. 切换成管理员,输入: su root 然后输入管理员密码,进行密码认证: 成功后,先在 /mnt 下建立一个名叫USB ...

  4. 使用React写的一个小小的登录验证密码组件

    哎,算了.直接上代码吧,不懂得私聊我把 <!DOCTYPE html> <html lang="en"> <head> <meta cha ...

  5. windbg载入目标模块pdb

    .reload /f xxxx.dll ld xxxx 以kdcom为例子 .reload /f kdcom.dll ld kdcom 二选一

  6. 窗口大小改变绑定resize事件

    当为窗口绑定resize事件时,大部分浏览器会在每改变一个像素就触发一次resize事件.这严重影响了网站的性能. 解决方案是:利用settimeout方法为事件发触发的方法设置延迟执行的时间. 实现 ...

  7. Lucene构建索引时的一些概念和索引构建的过程

    在搜索文档内容之前要做的事情就是对从各种不同来源(网页,数据库,电子邮件等)的文档进行索引,索引的过程就是对内容进行提取,规范化(通过对内容进行建模来实现),然后存储. 在索引的过程中有几个基本的概念 ...

  8. [USB] Windows USB/DVD Download Tool

    此工具为微软官方U盘启动盘制作工具 Windows USB/DVD Download Tool 说明:https://www.microsoft.com/en-us/download/windows- ...

  9. ios 图片拉伸不变形的方法

    如果一个椭圆图片,原图大小为30*30,而我们让它显示100*30,那么这个图片就会被拉伸,而且效果很难看.用下边的方法可以创建一个局部不被拉伸的图片. UIImage * buttonBg = [[ ...

  10. 【Android】Android--Dialog

    前言 对话框对于应用也是必不可少的一个组件,在Android中也不例外,对话框对于一些提示重要信息,或者一些需要用户额外交互的一些内容很有帮助.本篇博客就讲解一下Android下对话框的使用,在本篇博 ...