Codeforces Round #326(Div2)
CodeForces 588A
题意:Duff喜欢吃肉,想在接下来的n天,每天都有Ai斤肉吃,但每一天肉的单价Pi不定,肉 可以保存不过期,现已知n天每天肉的斤数Ai,以及单价Pi,为了使每天都 有想要的Ai斤肉吃,求最小花费。
思路:cost=Ai*min(pi) 1<=i<=n;
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
const int maxn=1e5+;
const int inf=0x3f3f3f3f;
int cost[maxn],p[maxn]; int main()
{
int d,minn,res;
while(~scanf("%d",&d))
{
res=;minn=inf;
for(int i=;i<d;i++)
{
scanf("%d%d",&cost[i],&p[i]);
if(p[i]<minn)
minn=p[i];
res+=cost[i]*minn;
}
printf("%d\n",res);
}
return ;
}
CodeForces 588B
题意:有一个数n,有多个因子,例如12={1,2,4,6,12},满足可爱数的条件是:为n的因子,并且这个数的因子数不能被开方。现求最大可爱数。
思路:数据较大1e12.
方案一、暴力+用sqrt减少循环次数。使时间复杂度达到根号n*根号根号n,即1e9.
方案二、打一个素数表,整数可以拆分成任意素数的乘积。
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
using namespace std;
long long n; bool deal(long long x)
{
long long y=sqrt(x)+;
for(long long i=;i<=y;i++)
if(x%(i*i)==)
return ;
return ;
} int main()
{
while(~scanf("%lld",&n))
{
long long m=sqrt(n);int flag=;
long long res;
for(long long i=;i<=m+;i++)
{
if(n%i==&&deal(n/i))
{
flag=;
res=n/i;
break;
}
}
if(!flag)
{
for(long long i=m;i>=;i--)
{
if(n%i==&&deal(i))
{
res=i;
break;
}
}
}
printf("%lld\n", res);
}
return ;
}
CodeForces 587A
题意:n个数,A1,A2.....An。选k(k<=n)个数,构成2^a1+2^a2+...2^ak=2^x(可为任意),算一次,一个数只能被选一次。求数全被选完最少需要多少次。
思路:可发现:2^2=2^1+2^1
2^3=2^2+2^2
2^4=2^3+2^3
......
2^n=2^(n-1)+2^(n-1)
由于n个数任意取,并且2^n=2^(n-1)+2^(n-1). 只看指数,即Ai,(1,1)=2, (2,2)=3, (n-1,n-1)=n
为了尽少次数的到底2^x. 需要统计Ai的个数。然后(1,1)=2, (2,2)=3, (n-1,n-1)=n,
一 直合成到最大。合成后剩下的次数即为result.
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int maxn=1e6+; int f[*maxn],a[maxn];
int n,res,maxx; void deal()
{
res=;
for(int i=;i<=maxn;i++)
{
if(f[i]%==)
{
f[i+]+=(f[i]-)/;
res++;
}
else
f[i+]+=f[i]/;
}
} int main()
{
while(~scanf("%d",&n))
{
memset(f,,sizeof(f));
maxx=-;
for(int i=;i<n;i++)
{
scanf("%d",&a[i]);
maxx=max(maxx,a[i]);
f[a[i]]++;
}
deal();
printf("%d\n",res);
}
return ;
}
剩下题目待补,革命尚未成功,同志仍需努力!
Codeforces Round #326(Div2)的更多相关文章
- Codeforces Round #328(Div2)
CodeForces 592A 题意:在8*8棋盘里,有黑白棋,F1选手(W棋往上-->最后至目标点:第1行)先走,F2选手(B棋往下-->最后至目标点:第8行)其次.棋子数不一定相等,F ...
- Codeforces Round #468(div2)
A Friends Meeting 题意:有两个人在数轴上的不同位置,现在他们需要到一个位置碰面.每次每人只能向左或向右走1个单位,轮流进行.每个人第一次走时疲劳度+1,第二次走时疲劳度+2,以此类推 ...
- Codeforces Round #329(Div2)
CodeForces 593A 题意:n个字符串,选一些字符串,在这些字符串中使得不同字母最多有两个,求满足这个条件可选得的最多字母个数. 思路:用c[i][j]统计文章中只有i,j对应两个字母出现的 ...
- Educational Codeforces Round 64(ECR64)
Educational Codeforces Round 64 CodeForces 1156A 题意:1代表圆,2代表正三角形,3代表正方形.给一个只含1,2,3的数列a,ai+1内接在ai内,求总 ...
- Codeforces Round #499(Div2) C. Fly (二分精度)
http://codeforces.com/contest/1011/problem/C 题目 这是一道大水题! 仅以此题解作为我这个蒟蒻掉分的见证 #include<iostream> ...
- codeforces Educational Codeforces Round 16-E(DP)
题目链接:http://codeforces.com/contest/710/problem/E 题意:开始文本为空,可以选择话费时间x输入或删除一个字符,也可以选择复制并粘贴一串字符(即长度变为两倍 ...
- cf_ducational Codeforces Round 16_D(gcd)
题意:求R-L区间满足x=a1*k+b1=a2*l+b2的x的个数; 思路:求出最小的满足条件的x0,则ans=(L-x)/(a1/gcd(a1, a2)*a2)+1; 注意剪枝,不然会超时: 代码: ...
- Codeforces Round #581(Div. 2)
Codeforces Round #581(Div. 2) CF 1204 A. BowWow and the Timetable 题解:发现,$4$的幂次的二进制就是一个$1$后面跟偶数个$0$. ...
- codeforces 572(Div2)A、B、C、D1、D2、E
Cdoeforces 572(Div2)A.B.C.D1.D2.E 传送门:https://codeforces.com/contest/1189 A.题意: 给你一串长为n的字符串,要求你将其切割为 ...
随机推荐
- ref 微软官网
https://docs.microsoft.com/zh-cn/previous-versions/14akc2c7(v=vs.110)
- hbase的coprocessor使用(转)
http://www.360doc.com/content/13/0320/09/4675893_272623864.shtml
- FTP服务安装及使用
准备工作:一台服务器.我这里使用的是阿里云的ECS. 环境使用的是:windows 2008 r2 用途:FTP是用来进行文件传输的,我们可以把这个目录在IIS上配置成发布的网站,我们在本地只用把我们 ...
- 【例题收藏】◇例题·I◇ Snuke's Subway Trip
◇例题·I◇ Snuke's Subway Trip 题目来源:Atcoder Regular 061 E题(beta版) +传送门+ 一.解析 (1)最短路实现 由于在同一家公司的铁路上移动是不花费 ...
- Yii2 设计模式
一. 单例模式 顾名思义, 单例模式就是只实例一次,通过一个接口去实现多处需要的同一类对象的需求. 例子: public function __construct($config = []) { Yi ...
- [Bzoj2282]消防(二分答案+树的直径)
Description 某个国家有n个城市,这n个城市中任意两个都连通且有唯一一条路径,每条连通两个城市的道路的长度为zi(zi<=1000). 这个国家的人对火焰有超越宇宙的热情,所以这个国家 ...
- js简单的获取与输出
js获取标签内容和输出内容到页面 获取: html: <select id="choiceSelect" onchange="changeImg()"&g ...
- Android 面试收集录5 消息机制
1.消息机制概述 1.1.消息机制的简介 在Android中使用消息机制,我们首先想到的就是Handler. 没错,Handler是Android消息机制的上层接口. Handler的使用过程很简单, ...
- 十二、mysql之视图,触发器,事务等
一.视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,可以将该结果集当做表来使用. 使用视图我们可以把查询过程中的 ...
- [EXCEL]使用技巧随记
1.比对两列中是否有重复项(B列中是否和A列重复) =IF(COUNTIF(A:A,B1)=0,"不重复","重复") Excel中用vlookup函数来对比两 ...