A:Rewards:

题目链接:http://codeforces.com/problemset/problem/448/A

题意:Bizon有a1个一等奖奖杯,a2个二等奖奖杯,a3个三等奖奖杯,b1个一等奖奖牌,b2个二等奖奖牌,b3个三等奖奖牌,和一个有n个架子的橱柜。如今Bizon想把这些奖牌和奖杯放在橱柜里,可是要遵循以下的规则:一个架子上不能同一时候放奖杯和奖牌;一个架子上的奖杯数量不能超过5个。奖牌数量不能超过10个。

问能不能把这些奖杯和奖牌所有放进去。

分析:依照贪心原则。一个架子上放尽可能多的奖杯和奖牌,求出须要多少个架子,与n比較大小就可以。

#include<cstdio>
#include<cstring>
#include<cmath>
#include<iostream>
#include<cstdlib>
#include<algorithm>
using namespace std;
int main()
{
int a1, a2, a3, b1, b2, b3, n;
while(~scanf("%d%d%d%d%d%d%d",&a1, &a2, &a3, &b1, &b2, &b3, &n))
{
int suma = a1 + a2 + a3;
int sumb = b1 + b2 + b3;
int cnta = suma / 5, cntb = sumb / 10;
if(suma % 5 != 0)
cnta++;
if(sumb % 10 != 0)
cntb++;
if(cnta + cntb <= n)
printf("YES\n");
else
printf("NO\n");
}
return 0;
}

B:Suffix Structures

题目链接:http://codeforces.com/problemset/problem/448/B

题意:给出两个串s和t,问能不能把s变成t,假设能够,输出变换时用的数据结构是什么?变换时能够使用两种数据结构:1.suffix
automaton,它能够删除串中的随意一个字符。2.suffix array,它能够交换串中的随意两个字符。

假设仅仅用到suffix
automaton,输出“automaton“;假设仅仅用到”suffix array“,输出”array“;假设两种都用到,输出”both“;假设变不成。输出“need
tree”。

分析:直接模拟就可以。

#include<cstdio>
#include<cstring>
#include<cmath>
#include<iostream>
#include<string>
#include<cstdlib>
#include<algorithm>
using namespace std;
int main()
{
string s, t;
int a[30], b[30];
while(cin >> s >> t)
{
memset(a, 0, sizeof(a));
memset(b, 0, sizeof(b));
if(s.length() < t.length())
{
cout << "need tree" << endl;
continue;
}
int ls = s.length(), lt = t.length();
if(ls == lt)
{
for(int i = 0; i < ls; i++)
{
a[s[i] - 'a']++;
b[t[i] - 'a']++;
}
int flag = 1;
for(int i = 0; i < 26; i++)
if(a[i] != b[i])
{
flag = 0;
break;
}
if(flag)
cout << "array" << endl;
else
cout << "need tree" << endl;
}
else
{
//cout << "s = " << s << ", t = " << t << endl;
for(int i = 0; i < ls; i++)
a[s[i] - 'a']++;
for(int i = 0; i < lt; i++)
b[t[i] - 'a']++;
int flag = 1, ok = 0;
for(int i = 0; i < 26; i++)
if(a[i] < b[i])
{
flag = 0;
break;
}
if(flag)
{
int j, k = 0;
for(int i = 0; i < ls; i++)
{
if(s[i] == t[k])
k++;
if(k == lt)
{
ok = 1;
break;
}
} //t中的字符在s中不一定连续出现,比如ababa abb,应是 aruomaton。比赛时一直Wa在这。 }
if(flag && ok)
cout << "automaton" << endl;
else if(flag && !ok)
cout << "both" << endl;
else
cout << "need tree" << endl;
}
}
return 0;
}

C.Painting Fence

题目链接:http://codeforces.com/problemset/problem/448/C

题意:Bizon要粉刷他的栅栏。栅栏由n块木板组成,每一块有个高度,每次stroke时必须一直接触着栅栏。问最少须要stroke多少次,能够把栅栏刷好。

分析:分治法。

把栅栏从最低处分成左右两部分,每一部分再这样分下去,直到仅仅剩下一块木板。然后往上返回最小值就可以。

#include<cstdio>
#include<algorithm>
using namespace std;
const int MAXN = 5005;
int a[MAXN];
int solve(int l, int r, int h)
{
int k = l, mmin = a[l];
if(l > r) return 0;
if(l == r) return a[l] > h;
for(int i = l; i <= r; i++)
if(a[i] < mmin)
{
k = i;
mmin = a[i];
}
return min(r-l+1, solve(l, k-1, mmin) + solve(k+1, r, mmin) + (mmin - h));
}
int main()
{
int n;
scanf("%d",&n);
for(int i = 0; i < n; i++)
scanf("%d",&a[i]);
printf("%d\n", solve(0, n-1, 0));
return 0;
} #include<cstdio>
#include<algorithm>
using namespace std;
const int MAXN = 5005;
int a[MAXN];
int solve(int l, int r)
{
int k = l;
if(l > r) return 0;
for(int i = l; i <= r; i++)
if(a[i] < a[k])
k = i;
int tmp = a[k];
for(int i = l; i <= r; i++)
a[i] -= tmp;
return min(r-l+1, solve(l, k-1) + solve(k+1, r) + tmp);
}
int main()
{
int n;
scanf("%d",&n);
for(int i = 0; i < n; i++)
scanf("%d",&a[i]);
printf("%d\n", solve(0, n-1));
return 0;
}

D:Multiplication Table

题目链接:http://codeforces.com/problemset/problem/448/D

题意:给出一个n行m列的乘法表,第i行第j列的值为i*j,把这些值从小到大排序,问第k个数是多少。

分析:二分。

#include<iostream>
using namespace std;
typedef long long LL;
LL solve(LL n, LL m, LL k)
{
LL l = 0, r = n * m;
while(r - l > 1)
{
LL mid = (r + l) / 2;
LL sum = 0;
for(int i = 1; i <= n; i++)
{
LL tmp = mid / i;
if(tmp > m) tmp = m;
sum += tmp; //sum为不大于mid的值的个数
}
if(sum >= k) r = mid;
else l = mid;
}
return r;
}
int main()
{
LL n, m, k;
while(cin >> n >> m >> k)
{
cout << solve(n, m, k) << endl;
}
return 0;
}

E:Divisors(dfs)

题目链接:http://codeforces.com/problemset/problem/448/E

题意:给出一个数n,把这个数的因子从小到大写出来,然后对这个数的因子运行k次同样的操作,问最后的结果是什么。假设结果超过100000位。仅仅输出前100000位。

分析:由于对每一个数运行的是同样的操作。所以能够用递归写,当运行到不能分解时,输出一个数,直到运行完k次或者个数已经达到了100000个结束。

#include<iostream>
#include<cmath>
#include<algorithm>
using namespace std;
typedef __int64 LL;
const int MAXN = 100000;
LL divisor[MAXN], num;
LL cnt = 0;
void get_divisor(LL x)
{
num = 0;
LL tmp = (LL)sqrt(x);
for(int i = 1; i <= tmp; i++)
{
if(x % i == 0){
divisor[num++] = i;
if(x / i != i)
divisor[num++] = x / i;
}
}
sort(divisor, divisor + num);
} void dfs(LL x, LL k)
{
//cout << "x = " << x << ", k = " << k << endl;
if(cnt >= 100000) return ;
if(k == 0 || x == 1)
{
cout << x << " ";
cnt++;
return ;
}
for(LL i = 0; i < num && divisor[i] <= x; i++)
{
if(x % divisor[i] == 0) {
dfs(divisor[i], k-1);
if(cnt >= 100000) return ;
}
}
} int main()
{
LL x, k;
while(cin >> x >> k)
{
get_divisor(x);
dfs(x, k);
cout << endl;
}
return 0;
}

CodeForces 448的更多相关文章

  1. Codeforces #448 Div2 E

    #448 Div2 E 题意 给出一个数组,有两种类型操作: 选定不相交的两个区间,分别随机挑选一个数,交换位置. 查询区间和的期望. 分析 线段树区间更新区间求和. 既然是涉及到两个区间,那么对于第 ...

  2. Codeforces 448 D. Multiplication Table

    二分法判断答案 D. Multiplication Table time limit per test 1 second memory limit per test 256 megabytes inp ...

  3. Codeforces 448 E. Divisors (DFS,储存结构)

    题目链接:E. Divisors 题意: 给出一个X,f(X)是X所有约数的数列(例6:1 2 3 6),给出一个k,k是递归的次数(例:k=2 : f(f(X)) ; X=4,k=2: 1 1 2 ...

  4. Codeforces 448 D. Multiplication Table 二分

    题目链接:D. Multiplication Table 题意: 给出N×M的乘法矩阵要你求在这个惩罚矩阵中第k个小的元素(1 ≤ n, m ≤ 5·10^5; 1 ≤ k ≤ n·m). 题解: n ...

  5. Codeforces 448 C. Painting Fence

    递归.分治. . . C. Painting Fence time limit per test 1 second memory limit per test 512 megabytes input ...

  6. Codeforces Round #448 C. Square Subsets

    题目链接 Codeforces Round #448 C. Square Subsets 题解 质因数 *质因数 = 平方数,问题转化成求异或方程组解的个数 求出答案就是\(2^{自由元-1}\) , ...

  7. CodeForces:#448 div2 B. XK Segments

    传送门:http://codeforces.com/contest/895/problem/B B. XK Segments time limit per test1 second memory li ...

  8. CodeForces:#448 div2 a Pizza Separation

    传送门:http://codeforces.com/contest/895/problem/A A. Pizza Separation time limit per test1 second memo ...

  9. Codeforces Round #448(Div.2) Editorial ABC

    被B的0的情况从头卡到尾.导致没看C,心情炸裂又掉分了. A. Pizza Separation time limit per test 1 second memory limit per test ...

随机推荐

  1. 《JavaScript+DOM编程艺术》的摘要(一)---基本知识点

    保持良好的编程习惯:在同一脚本中,保持引号的一致性,都用单引 var mood = "don\"t worry";alert(mood); 数组:var arr=Arra ...

  2. hdu 3518 Boring counting 后缀数组

    题目链接 根据height数组的性质分组计算. #include <iostream> #include <vector> #include <cstdio> #i ...

  3. printf与scanf的返回值、注意点

    printf()的返回值为其输出字符串常量的字符数(注意字符数与字数的区别)注意计数针对所有的打印字符,包括空格和不可见的换行字符(不包括字符串的空字符). scanf()函数返回成功读入的项目的个数 ...

  4. 未能从程序集“System.ServiceModel, Version=3.0.0.0”中加载类型“System.ServiceModel.Activation.HttpModule” 的解决办法

    未能从程序集“System.ServiceModel, Version=3.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089”中加载类型“ ...

  5. 关于mysqli 连接数不能正确释放的解决方案

    /** * 析构函数 */ //解决重复链接的问题 private $db_handler = null; function __destruct() { Log::logWrite($this-&g ...

  6. 2015 11 27编写JAVA程序

    在任意文件下 ,建立一个文本文档,更改其txt格式为java格式, 打开此程序的同时打开eclipse可编写代码. public class 文件名{ public static void main( ...

  7. 自己动手写处理器之第一阶段(3)——MIPS32指令集架构简单介绍

    将陆续上传本人写的新书<自己动手写处理器>(尚未出版).今天是第四篇.我尽量每周四篇 1.4 MIPS32指令集架构简单介绍 本书设计的处理器遵循MIPS32 Release 1架构,所以 ...

  8. 第一章 什么是SQL Server Integration Services (ssis) 系统。

    note:我也是刚入门的菜鸟,让我们大家一块学习SSIS系统,工作中需要用到SSIS.您的浏览是我更新的最大动力,谢谢!  SSIS是Microsoft SQL Server Integration ...

  9. JS年月日三级联动下拉框日期选择代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  10. [转]Win7、Windows Server 2008下无法在Windows Service中打开一个已经存在的Excel 2007文件问题的解决方案

    昨天,组里一个小朋友告诉我,他写的报表生成服务中无法打开一个已经存在的Excel 2007文件,他的开发环境是Win7.Visual Studio .Net 2008(Windows Server 2 ...