今天学长给我们挂了一套Div.1的题,难受,好难啊。

Problem A:

题目大意:给你n个数字,让你叠成n堆,每个数字上面的数的个数不能超过这个数,如 3 上面最多放三个数字

问你,最少能放几堆。

刚开始看错题意,以为只要比这个数字小的数都能放上去,后来看清了题意,一直想的是怎么从下往上放,感觉

二分加贪心可以做,但是太麻烦了,后来想如果从上往下放就好做多了,每次从小的开取,这样到取下一个数的

时候就知道上面有多少,能不能取这个数,这样的话也能保证这一堆是最优的。

#include<bits/stdc++.h>
using namespace std;
int a[],n;
bool vis[];
int main()
{
scanf("%d",&n);
for(int i=;i<n;i++) scanf("%d",&a[i]);
sort(a,a+n);
int sum=n;
int ans=;
int now=;
while(sum)
{
//cout<<sum<<endl;
for(int i=;i<n;i++)
{
if(!vis[i])
{
if(a[i]>=now)
{
now++;
vis[i]=;
sum--;
}
}
}
ans++;
now=;
}
cout<<ans<<endl;
return ;
}

Problem B:

题目大意:让你给出一幅图,让这幅图从1节点到2节点的最短路的条数为k,且节点个数不能超过1000个。

思路:如果没有节点个数的限制那么这题就非常好些,但有了限制的话其实我们可以这么想,我们可以把

k用2进制表示,这样就能将条数表示成2*2*2...+2*2...的方式。刚写的时候每条单链都是新的,取极限值的

时候会超过1000个节点,于是我就先预处理处一条长度为100的单链重复利用。

#include<bits/stdc++.h>
using namespace std;
int k;
int a[],pos;
bool vis[][];
int len[];//len[i]表示还需要增加i长度的链需要接在那个节点上
int main()
{
vis[][]=vis[][]=;
len[]=;
len[]=;
int ct=;
for(int i=;i>=;i--)
{
vis[i][i-]=vis[i-][i]=;
len[++ct]=i-;
}
cin>>k;
pos=;
while(k)
{
a[pos++]=k&;
k=k>>;
}
pos--;
int cnt=;
for(int i=pos;i>=;i--)
{
if(a[i])
{
for(int j=;j<=i;j++)
{
if(j==)
{
cnt++;
vis[cnt][]=;
vis[][cnt]=;
cnt++;
vis[cnt][]=;
vis[][cnt]=;
}
else
{
cnt++;
vis[cnt][cnt-]=vis[cnt-][cnt]=;
vis[cnt][cnt-]=vis[cnt-][cnt]=;
cnt++;
vis[cnt][cnt-]=vis[cnt-][cnt]=;
vis[cnt][cnt-]=vis[cnt-][cnt]=;
}
}
if(i==pos)
{
vis[cnt][]=vis[][cnt]=;
vis[cnt-][]=vis[][cnt-]=;
}
else
{
if(!i) vis[][len[pos+]]=vis[len[pos+]][]=;
else
{
vis[cnt][len[pos-i+]]=vis[len[pos-i+]][cnt]=;
vis[cnt-][len[pos-i+]]=vis[len[pos-i+]][cnt-]=;
}
}
}
}
cout<<""<<endl;
for(int i=;i<=;i++)
{
for(int j=;j<=;j++)
{
if(vis[i][j] && i!=j) printf("Y");
else printf("N");
}
puts("");
}
return ;
}

Problem C:

题目大意:有n堆牌,A只能从顶部取牌,B只能从底部取牌,A先取,如果每个人都希望自己的点数总和

最大,且每个人的操作都最优,问你最后两个人的点数分别是什么。

思路:这个题还是比较简单的贪心,我们可以这么想,我们把每堆牌都分成上堆和下堆,如果是奇数则

把中间的牌取出来放到一个数组里。如果对A来说下堆有对他有利的大牌,他会想去拿,但是B也是最优

操作,B不会让A拿到,对B来说也是同理,所以最后肯定上堆都是A的下堆都是B的,奇数堆取出来的一

个一个分。

#include<bits/stdc++.h>
using namespace std;
vector<int> zhong;
bool cmp(int a,int b)
{
return a>b;
}
int main()
{
int n;
cin>>n;
int sum1=,sum2=;
for(int i=;i<=n;i++)
{
int m;
scanf("%d",&m);
if(m%==)
{
for(int i=;i<=m;i++)
{
int g;scanf("%d",&g);
if(i<=m/) sum1+=g;
else sum2+=g;
}
}
else
{
for(int i=;i<=m;i++)
{
int g;scanf("%d",&g);
if(i<=m/) sum1+=g;
else if(i==m/+) zhong.push_back(g);
else sum2+=g;
}
}
}
sort(zhong.begin(),zhong.end(),cmp);
for(int i=;i<zhong.size();i++)
{
if(i%==) sum1+=zhong[i];
else sum2+=zhong[i];
}
printf("%d %d\n",sum1,sum2);
return ;
}

Codeforces Round #228 (Div. 1)的更多相关文章

  1. Codeforces Round #228 (Div. 2) C. Fox and Box Accumulation(贪心)

    题目:http://codeforces.com/contest/389/problem/C 题意:给n个箱子,给n个箱子所能承受的重量,每个箱子的重量为1: 很简单的贪心,比赛的时候没想出来.... ...

  2. Codeforces Round #228 (Div. 1) C. Fox and Card Game 博弈

    C. Fox and Card Game 题目连接: http://codeforces.com/contest/388/problem/C Description Fox Ciel is playi ...

  3. Codeforces Round #228 (Div. 1) B. Fox and Minimal path 构造

    B. Fox and Minimal path 题目连接: http://codeforces.com/contest/388/problem/B Description Fox Ciel wants ...

  4. Codeforces Round #228 (Div. 1) A. Fox and Box Accumulation 贪心

    A. Fox and Box Accumulation 题目连接: http://codeforces.com/contest/388/problem/A Description Fox Ciel h ...

  5. Codeforces Round #228 (Div. 1) 388B Fox and Minimal path

    链接:http://codeforces.com/problemset/problem/388/B [题意] 给出一个整数K,构造出刚好含有K条从1到2的最短路的图. [分析] 由于是要自己构造图,当 ...

  6. Codeforces Round #228 (Div. 2)

    做codeforces以来题目最水的一次 A题: Fox and Number Game 题意:就是用一堆数字来回减,直到减到最小值为止,再把所有最小值加,求这个值 sol: 简单数论题目,直接求所有 ...

  7. Codeforces Round #228 (Div. 2) B. Fox and Cross

    #include <iostream> #include <string> #include <vector> #include <algorithm> ...

  8. Codeforces Round #228 (Div. 2) A. Fox and Number Game

    #include <iostream> #include <algorithm> #include <vector> #include <numeric> ...

  9. Codeforces Round #228 (Div. 1) B

    B. Fox and Minimal path time limit per test 1 second memory limit per test 256 megabytes input stand ...

随机推荐

  1. IDA Pro使用技巧

    DA Pro基本简介 IDA加载完程序后,3个立即可见的窗口分别为IDA-View,Named,和消息输出窗口(output Window). IDA图形视图会有执行流,Yes箭头默认为绿色,No箭头 ...

  2. mipsel汇编指令学习

    MIPS汇编语言基础 MIPS的系统结构及设计理念比较先进,其指令系统经过通用处理器指令体系MIPS I.MIPS II.MIPS III.MIPS IV.MIPS V,以及嵌入式指令体系MIPS16 ...

  3. .net 重新注册

    今天同事问 一个IIS 的监控站点 .net 出现问题:对于windows 一般都停留在重启生效思想:然并没有生效: 于是建议重新注册.NET : 一般出现原因: 在默认安装路径 重启注册: 默认的安 ...

  4. luogu P1072 $Hankson$ 的趣味题

    这里提供两种做法 sol 1 考虑两个数\(A,B\)和\(C=gcd(A,B),D=lcm(A,B)\)的关系 设\(S=\{2,3,5...P_n\}\)为质数集合\(p_{x,i}\)表示\(x ...

  5. vue学习之用 Vue.js + Vue Router 创建单页应用的几个步骤

    通过vue学习一:新建或打开vue项目,创建好项目后,接下来的操作为: src目录重新规划——>新建几个页面——>配置这几个页面的路由——>给根实例注入路由配置 src目录重整 在项 ...

  6. Web前端的缓存机制(那些以代价换来的效率)

    对于Web前端而言,cache可以说是无处不在,通常是2个环节之间,就会引入一个cache做为提升整体效率的角色.例如A和B两者之间的数据交换,为了提升整体的效率,引入角色C,而C被用于当做热点数据的 ...

  7. Python 爬虫学习

    #coding:utf-8 #author:Blood_Zero ''' 1.获取网页信息 2.解决编码问题,通过charset库(默认不安装这个库文件) ''' import urllib impo ...

  8. 【黑客免杀攻防】读书笔记5 - PE格式讲解

    0x01 MS-DOS头 MS-DOS头部的字段重点关注e_magic与最后一个e_lfanew是需要关注的. 第一个e_magic字段的值为4D5A,作用是可以作为判断这个文件是否是PE文件. 最后 ...

  9. 一个python脚本解决安装mq的依赖问题

    import tarfile import sys,os from _utils.patrol2 import run_cmd import zipfile def get_version(filen ...

  10. centos6.5环境下svn服务器和客户端配置实用详解

    一.服务器端配置 安装 # yum install -y subversion yum安装软件,不清除软件包的方法 # vim /etc/yum.conf keepcache=0 建立svn版本库数据 ...