刚好在考完当天有一场div3,就开了个小号打了,打的途中被辅导员喊去帮忙,搞了二十分钟-_-||,最后就出了四题,题解如下:
题目链接:http://codeforces.com/contest/1003

题目:

思路:求众数出现的次数

代码如下:

 #include <bits/stdc++.h>
using namespace std; typedef long long ll;
#define debug(x) cout <<"[" <<x <<"]" <<endl const int inf = 0x3f3f3f3f;
const int maxn = 1e5 + ; int n;
int a[], vis[]; int main() {
cin >>n;
int mx = -;
for(int i = ; i < n; i++) {
cin >>a[i];
vis[a[i]]++;
if(mx < vis[a[i]]) {
mx = vis[a[i]];
}
}
cout <<mx <<endl;
return ;
}

题目:

思路:构造一个01串,其中0的个数为a,1的个数为b,中间刚好有k次01的交替,题目保证有解。模拟即可。

代码实现如下:

 #include <bits/stdc++.h>
using namespace std; int a, b, x, flag;
int vis[]; int main() {
cin >> a >> b >> x;
int flag = x & ;
if(a >= b) {
vis[] = ;
a--;
for(int i = ; i < x; i++) {
vis[i] = !vis[i-];
if(i & ) b--;
else a--;
}
for(int i = ; i < x; i++) {
cout <<vis[i];
}
if(flag) {
for(int i = ; i < a; i++) {
cout <<"";
}
for(int i = ; i < b; i++) {
cout <<"";
}
} else {
for(int i = ; i < b; i++) {
cout <<"";
}
for(int i = ; i < a; i++) {
cout <<"";
}
}
cout <<endl;
} else {
vis[] = ;
b--;
for(int i = ; i < x; i++) {
vis[i] = !vis[i-];
if(i & ) a--;
else b--;
}
for(int i = ; i < x; i++) {
cout <<vis[i];
}
if(flag) {
for(int i = ; i < b; i++) {
cout <<"";
}
for(int i = ; i < a; i++) {
cout <<"";
}
} else {
for(int i = ; i < a; i++) {
cout <<"";
}
for(int i = ; i < b; i++) {
cout <<"";
}
}
cout <<endl;
}
return ;
}

题目:

思路:求长度大于等于k的连续字串的平均值的最大值,因为本题数据小,可以用n^2水过,数据大了需要用二分,这里就只贴比赛时写的n^2的代码了~先用一个前缀和来维护分子,分母用一个循环处理。

代码如下:

 #include <bits/stdc++.h>
using namespace std; const int maxn = * ;
const double eps = 1e-;
int n, k;
double ans;
int a[maxn], sum[maxn]; int main() {
scanf("%d%d", &n, &k);
sum[] = ;
for(int i = ; i <= n; i++) {
scanf("%d", &a[i]);
sum[i] = sum[i-] + a[i];
}
ans = -;
for(int i = ; i <= n; i++) {
for(int j = k; j <= n; j++) {
double t = 1.0 * (sum[i + j - ] - sum[i-]) / j;
if(t - ans >= eps) {
ans = t;
}
}
}
printf("%.7f\n", ans);
return ;
}

题目:

题意:给你n个数,ai保证是2的幂次,q次查询,每次查询给你一个数x,问使用最少的a来组成这个数,如果无法组成就输出-1.

思路:先将ai转换成2^t,用个数组来储存;将x转换成二进制,然后从最大为开始贪心,当题目给的某一次方(t次方)不够时,就用2个t-1次方来构成一个t次方,最后判断0次方是否足够即可。用样例来解释:题目给的2的1次方有2个,2次方有2个,3次方有1个。第一个x的二进制为1000,需要一个2的3次方,题目给的刚好有一个3次方,因此答案为1;第二个x的二进制为101,需要2的2次方1个,0次方1个,2次方足够,但是没有0次方,所以答案为-1;第三个x的二进制为1110,需要1个3次方,1个2次方,1个1次方,均足够,故为3。

代码实现如下:

 #include <bits/stdc++.h>
using namespace std; const int maxn = 2e5 + ;
int n, q, t;
int a[maxn], b[maxn], num[], p[];
long long vis[maxn]; void prepare() {
vis[] = ;
for(int i = ; i < ; i++) {
vis[i] = vis[i-] * ;
}
} int main() {
prepare();
cin >>n >>q;
for(int i = ; i < n; i++) {
cin >>a[i];
t = lower_bound(vis, vis + , a[i]) - vis;
num[t]++;
}
for(int i = ; i < q; i++) {
cin >>b[i];
int k = , ans = ;
while(b[i]) {
p[k++] = b[i] % ;
b[i] = b[i] / ;
}
for(int j = k - ; j >= ; j--) {
if(num[j] < p[j]) {
ans += num[j];
p[j-] += * (p[j] - num[j]);
} else {
ans += p[j];
}
}
if(num[] < p[]) cout <<"-1" <<endl;
else cout <<ans + p[] <<endl;
}
return ;
}

赛后补题,一定要假装出是自己比赛时A的~

题目:

题意:生成一棵树,树的直径(本题的直径是指两节点间距离的最大值)为d,度数不超过k。

思路:首先生成一条链,此处节点分别为1~d+1,然后以这条链上的节点为根生成树,用dfs处理,此处生成的树的深度为min(i-1,d-i+1)(因为两节点间的距离不能超过d嘛~),注意处理NO的情况。

代码实现如下:

 #include <bits/stdc++.h>
using namespace std; const int maxn = 4e5 + ;
int n, k, d, cnt;
vector<int> G[maxn]; void dfs(int u, int deep, int mx) {
if(deep == mx) return;
for(int i = ; i < k - - (deep == ) && cnt < n; i++) {
int v = ++cnt;
G[u].push_back(v);
dfs(v, deep + , mx);
}
} int main() {
cin >>n >>d >>k;
if(k==){
if(n!= || d!=)printf("NO\n");
else printf("YES\n1 2\n");
return ;
}
if(d >= n) {
cout <<"NO" <<endl;
return ;
}
for(int i = ; i <= d; i++) {
G[i].push_back(i+);
}
cnt = d + ;
for(int i = ; i <= d + ; i++) {
dfs(i, , min(i - , d - i + ));
}
if(cnt < n) {
cout <<"NO" <<endl;
return ;
}
cout <<"YES" <<endl;
for(int i = ; i <= n; i++) {
for(int j = ; j < G[i].size(); j++) {
cout <<i <<" " <<G[i][j] <<endl;
}
}
return ;
}

Codeforces Round #494 (Div. 3)的更多相关文章

  1. Codeforces Round #494 (Div 3) (A~E)

    目录 Codeforces 1003 A.Polycarp's Pockets B.Binary String Constructing C.Intense Heat D.Coins and Quer ...

  2. Codeforces Round #494 (Div. 3) D. Coins and Queries(贪心

    题目链接 题目大意:给你n个物品,第iii个物品价值aia_iai​,询问q次,问你能不能凑出价值为qiq_iqi​的物品. 小贪心吧.从大到小找,能拿就拿就行了. #include<bits/ ...

  3. Codeforces Round #494 (Div. 3) D. Coins and Queries (贪心,数学)

    题意:给你一组全是\(2^d\ (d\ge0)\)的数,询问q次,每次询问一个数,问这个数是否能够由原数组中的数相加得到,如果能,输出最少用多少个数,否则输出\(-1\). 题解:首先贪心得出结论:如 ...

  4. Codeforces Round #366 (Div. 2) ABC

    Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...

  5. Codeforces Round #354 (Div. 2) ABCD

    Codeforces Round #354 (Div. 2) Problems     # Name     A Nicholas and Permutation standard input/out ...

  6. Codeforces Round #368 (Div. 2)

    直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...

  7. cf之路,1,Codeforces Round #345 (Div. 2)

     cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅.....   ...

  8. Codeforces Round #279 (Div. 2) ABCDE

    Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems     # Name     A Team Olympiad standard input/outpu ...

  9. Codeforces Round #262 (Div. 2) 1003

    Codeforces Round #262 (Div. 2) 1003 C. Present time limit per test 2 seconds memory limit per test 2 ...

随机推荐

  1. phpcms退出 提示 :退出成功0 。 的解决办法

    打开/phpcms/modules/member/index.php 搜索如下代码: showmessage(L('logout_success').$synlogoutstr, $forward); ...

  2. MySQL必备命令

    来源:http://www.cnblogs.com/liushuijinger/p/3381775.html 今天跟大家分享一下MySQL从连接到具体操作的一系列常用命令.可能有的人觉得现在有很多可视 ...

  3. ajax 请求 后台返回的文件流

    download(url) { var xhr = new XMLHttpRequest(); xhr.open('GET', url, true); // 也可以使用POST方式,根据接口 xhr. ...

  4. bzoj2437-兔兔与蛋蛋

    题目 分析 第一次做这种题,其实很简单. 只能经过一次的博弈可以考虑转化为二分图博弈. 棋盘上有黑白色的棋子,可以把这个游戏看作空格在棋子间移动,于是就想到,把棋盘黑白染色,以空格为黑,那么空格的移动 ...

  5. 【bzoj2259】[Oibh]新型计算机 堆优化Dijkstra

    题目描述 Tim正在摆弄着他设计的“计算机”,他认为这台计算机原理很独特,因此利用它可以解决许多难题. 但是,有一个难题他却解决不了,是这台计算机的输入问题.新型计算机的输入也很独特,假设输入序列中有 ...

  6. 【Codeforces Round #404 (Div. 2)】题解

    A. Anton and Polyhedrons 直接统计+答案就可以了. #include<cstdio> #include<cstring> #include<alg ...

  7. [ZJOI2010]贪吃的老鼠 网络流

    ---题面--- 题解: 这是一道强题emmmm,做法非常巧妙,,,我也是看了好久大佬题解才看明白一点 首先考虑没有限制的情况,即n个老鼠可以在同一时刻吃同一块奶酪 对各个时间段拆点,连奶酪 ---& ...

  8. [bzoj] 2049 洞穴勘探 || LCT

    原题 这是一道LCT的板子题. 至于LCT--link cut tree,也叫动态树,用splay实现动态连边的树. 预备知识: 实边:一个非叶节点,向它的儿子中的一个连一条特殊的边,称为实边;该非叶 ...

  9. Kindle 电子书相关的工具软件【转】

    这里是与 Kindle 电子书相关的工具软件.它们可以帮助我们解决在日常使用电子书时所可能遇到的问题,比如 kindle 管理工具.kindle 转换工具.kindle电子书制作工具.kindle 推 ...

  10. bzoj2144: 跳跳棋(二分/倍增)

    思维好题! 可以发现如果中间的点要跳到两边有两种情况,两边的点要跳到中间最多只有一种情况. 我们用一个节点表示一种状态,那么两边跳到中间的状态就是当前点的父亲,中间的点跳到两边的状态就是这个点的两个儿 ...