CF#190DIV.1
/*
CF#190DIV.1-C
题意:给你n个结点的树,给这些结点标记字母AB..Z,对于标记相同的结点路径上
的结点的标记必须有一个是大于该标记的;问是否可以标记(A是最大标记) 分析:整天思路就是找一个点,然后标记为最大标记i,然后再分别以最大标记i+1,标记该点的子树
依次递归;最终如果标记<=Z就是可以的;
因为只有10^5个点,最长情况下需要logn个不同的标记对于n个结点的树(成一条链)
2^26>log(10^5) 所以必定有解; 而那个点,最优的应该就是树的重心,重心的定义:去掉这个点后,树给分成a个连通分量,每个连通分量
仍然是一棵树,并且a个连通分量中最大结点数最小; 求法:这棵树的结点树为all,dfs()下去,同时记录该结点每棵子树的结点个数,那么该结点的
父亲结点那棵子树的结点树就是all-sum_soncnt-1;
用di[i]表示结点i的子树中结点个数最大的数,那么di[]最小的那个点就是重心 */
#include<cstdio>
#include<cstring>
#include<iostream>
#include<cmath>
#include<algorithm>
#include<cstdlib>
#include<vector>
using namespace std;
const int N=+;
vector<int> edge[N];
int n;
int how[N];
int di[N];
void read(){
memset(how,-,sizeof(how));
for (int i=;i<=n;i++) edge[i].clear();
for (int i=;i<n-;i++){
int u,v;scanf("%d%d",&u,&v);
edge[u].push_back(v);
edge[v].push_back(u);
}
} int son_cnt[N];
void find_center(int rt,int fa,int &id,int all){
int sum=,tmp=;
for (int i=;i<edge[rt].size();i++){
int c=edge[rt][i];
if (how[c]!=- || c==fa) continue;
find_center(c,rt,id,all);
sum+=son_cnt[c];
tmp=max(tmp,son_cnt[c]);
}
di[rt]=max(tmp,all-sum);
if (id==- || di[id]>di[rt]) id=rt;
son_cnt[rt]=sum;
}
void findall(int rt,int fa,int &all){
all++;
for (int i=;i<edge[rt].size();i++){
int c=edge[rt][i];
if (how[c]!=- || c==fa)continue;
findall(c,rt,all);
}
}
void work(int rt,int tar){
int all=;
findall(rt,-,all); int id=-;
find_center(rt,-,id,all); how[id]=tar;
for (int i=;i<edge[id].size();i++){
int c=edge[id][i];
if (how[c]!=-) continue;
work(c,tar+);
} }
int main(){
while (~scanf("%d",&n)){
read();
work(,);
for (int i=;i<n;i++){
printf("%c ",how[i]+'A');
}printf("%c\n",how[n]+'A');
}
return ;
}
/*
CF#190DIV.1-B
题意:看过游戏王的人的知道,现在轮到你攻击了,问你能给对方照成的最大伤害是多少
一次有效的攻击必须是己方的怪兽的攻击力大于等于对方的攻击了;
对方怪兽成防御状况攻击没有伤害,成攻击状况伤害为己方攻击减去对方攻击力 分析:题解里有很多种方法,贪心,dp,最小费用最大流
下面是贪心:分两类,一类是能达到直接攻击的方案,一类是不能达到直接攻击的方案 写代码遇到的问题:
下面代码中标记为$的那一行代码,位置放到了下面标记@的位置,导致当n3==0时,并且
前一组数据使v2[0]>v3[0],导致样例跑挂,这个错误很难找出来,如果没有数据的话,
所以如果清空的代价很小,那么能清空的就清空,该早点判断就早点判断 */
#include<cstdio>
#include<cstring>
#include<iostream>
#include<cstdlib>
#include<algorithm>
#include<cmath>
#include<vector>
using namespace std;
typedef long long LL;
const int N=+;
int n,m;
int f[N],v1[N],v2[N];
int ans;
int work(){
int flag1=;
int v3[N],v4[N],n3=,n4=;
for (int i=;i<n;i++){
if (f[i]==) v3[n3++]=v1[i];
else v4[n4++]=v1[i];
}
sort(v3,v3+n3); sort(v4,v4+n4);
int vis[N];
memset(vis,,sizeof(vis));
sort(v2,v2+m);
int j=;
for (int i=;i<m;i++){
if (j==n3) break;//$
if (v2[i]>v3[j]){
vis[i]=;
j++;
}
/*if (j==n3) break;@*/
}
if (j!=n3) flag1=;
j=;
for (int i=;i<m;i++){
if (j==n4) break;
if (vis[i]==){
if (v2[i]>=v4[j]){
j++;
} }
}
if (j!=n4) flag1=; int sum1=,sum2=;
for (int i=;i<m;i++) if (vis[i]==) sum1+=v2[i];
for (int i=;i<n4;i++) sum2+=v4[i];
if (flag1==)ans=max(ans,sum1-sum2); j=m-;
int tmp=;
for (int i=;i<n4;i++){
if (v2[j]>=v4[i]) {
tmp+=v2[j]-v4[i];
j--;
}
}
ans=max(ans,tmp);
cout<<ans<<endl; }
int main(){
// cout<<4%0<<endl;
while (cin>>n>>m){
char s[];
ans=;
for (int i=;i<n;i++){
scanf("%s%d",s,v1+i);
if(s[]=='A') f[i]=;
else f[i]=;
}
for (int i=;i<m;i++) scanf("%d",v2+i);
work();
} return ;
}
/*
CF#190DIV.1-A
题意:一个机器人站在原地(0,0)给你一串只包含UDLR的字符串,机器人只能按照这个串的顺序
来前进,并且可以无限次重复,问时候可以到达(a,b); 分析:有一些trick,比如循环的次数只能是正数,不能除零
还是刚开始就分类分清楚的好,不然代码中的一些逻辑真得搞不清楚 */
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<cmath>
#include<cstdio>
#include<algorithm>
using namespace std;
typedef long long LL;
const int N=+;
char s[N];
const int nx[]={,,-,};
const int ny[]={,-,,};
LL a,b;
LL X,Y;
void init(){
X=Y=;
for (int i=;s[i];i++){
int j;
if (s[i]=='U') j=;
else if (s[i]=='D') j=;
else if (s[i]=='L') j=;
else if (s[i]=='R') j=;
X+=nx[j]; Y+=ny[j];
}
}
void work(){
int tx=,ty=;
int flag=;
for (int i=;s[i];i++){
if (X== && Y==){
if (a==tx && b==ty) flag=;
}else if (X== && Y!=){
if (a==tx && (b-ty)%Y== && (b-ty)/Y>=) flag=;
}else if (X!= && Y==){
if (b==ty && (a-tx)%X== && (a-tx)/X>=) flag=;
}else if (X!= && Y!=){
if ((a-tx)%X== && (b-ty)%Y== && (a-tx)/X==(b-ty)/Y && (a-tx)/X>=) flag=;
}
if (flag) break;
int j;
if (s[i]=='U') j=;
else if (s[i]=='D') j=;
else if (s[i]=='L') j=;
else if (s[i]=='R') j=;
tx+=nx[j]; ty+=ny[j];
}
puts(flag?"Yes":"No");
}
int main(){
while (cin>>a>>b){
scanf("%s",s);
init();
work();
} return ;
}
CF#190DIV.1的更多相关文章
- ORA-00494: enqueue [CF] held for too long (more than 900 seconds) by 'inst 1, osid 5166'
凌晨收到同事电话,反馈应用程序访问Oracle数据库时报错,当时现场现象确认: 1. 应用程序访问不了数据库,使用SQL Developer测试发现访问不了数据库.报ORA-12570 TNS:pac ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- cf Round 613
A.Peter and Snow Blower(计算几何) 给定一个点和一个多边形,求出这个多边形绕这个点旋转一圈后形成的面积.保证这个点不在多边形内. 画个图能明白 这个图形是一个圆环,那么就是这个 ...
- ARC下OC对象和CF对象之间的桥接(bridge)
在开发iOS应用程序时我们有时会用到Core Foundation对象简称CF,例如Core Graphics.Core Text,并且我们可能需要将CF对象和OC对象进行互相转化,我们知道,ARC环 ...
- [Recommendation System] 推荐系统之协同过滤(CF)算法详解和实现
1 集体智慧和协同过滤 1.1 什么是集体智慧(社会计算)? 集体智慧 (Collective Intelligence) 并不是 Web2.0 时代特有的,只是在 Web2.0 时代,大家在 Web ...
- CF memsql Start[c]UP 2.0 A
CF memsql Start[c]UP 2.0 A A. Golden System time limit per test 1 second memory limit per test 256 m ...
- CF memsql Start[c]UP 2.0 B
CF memsql Start[c]UP 2.0 B B. Distributed Join time limit per test 1 second memory limit per test 25 ...
- CF #376 (Div. 2) C. dfs
1.CF #376 (Div. 2) C. Socks dfs 2.题意:给袜子上色,使n天左右脚袜子都同样颜色. 3.总结:一开始用链表存图,一直TLE test 6 (1)如果需 ...
- CF #375 (Div. 2) D. bfs
1.CF #375 (Div. 2) D. Lakes in Berland 2.总结:麻烦的bfs,但其实很水.. 3.题意:n*m的陆地与水泽,水泽在边界表示连通海洋.最后要剩k个湖,总要填掉多 ...
随机推荐
- C# WebBrowser准确判断网页最终装载完毕
== 最近写了个软件叫WebAutoScript,目的用于,网页的自动操作处理,就是说,所有你在网页上面的操作,都可以录到一个脚本中,然后可以回放这个操作过程..我是说任何过程. 程序是用C#写的,其 ...
- trackr: An AngularJS app with a Java 8 backend – Part I
该系列文章来自techdev 我想分享在techdev公司开发的项目-trackr-的一些最新的见解.trackr是一个用来跟踪我们的工作时间,创建报告和管理请假的web应用程序.做这个程序的目的有两 ...
- 一台电脑同时运行多个tomcat配置方法
当第一个tomcat启动后,后面tomcat的server.xml中的端口不管怎么改,仍然会报端口冲突.后来在dos下运行才发现所有的tomcat都会去找CATALINA_HOME和CATALINA_ ...
- 二维树状数组(水题) POJ1195
前段时间遇到线段树过不了,树状数组却过了的题.(其实线段树过得了的) 回忆了下树状数组. 主要原理,还是二进制位数,每一项的和表示其为它的前((最后一位1及其后)的二进制数)和,可从二进制图来看.(用 ...
- 终极解决方案:windows10开机黑屏,死机
windows10开机黑屏,死机一般情况都是由于双显卡中的独立显卡驱动造成的! 那么试着升级一下你的BIOS吧!一定要在官网下载你对应的BIOS驱动,然后双击安装,这个时候就别再动机子了,让他自己刷新 ...
- C#委托的介绍(delegate、Action、Func、predicate)【转】
转自 http://www.cnblogs.com/akwwl/p/3232679.html 委托是一个类,它定义了方法的类型,使得可以将方法当作另一个方法的参数来进行传递.事件是一种特殊的委托. 1 ...
- jquery 字符串转json
这里考虑的都是服务器返回JSON形式的字符串的形式 代码如下: var data=" { root: [ {name:'1',value:'0'}, {name:'6101',value:' ...
- fancybox 无效 失效 直接打开页面, ajax 之后 fancybox对更新的数据无效,Jquery失效 无效
案例:做个聊天室项目,数据都是通过ajax刷新出来的,而对新数据绑定的fancybox均无效,点击直接打开到了新页面而不是弹窗,解决方法其实很简单 简单分析:ajax加载内容是在$(documen ...
- php复制目录及文件
<?php /* 复制目录 */ function copydir($dirsrc,$dirto){ if(is_file($dirto)){ echo "目标不是目录不能创建&quo ...
- Oracle 课程三之表设计
完成本课程的学习后,您应该能够: •普通堆表优点和缺点 •理解rowid •全局临时表优点.缺点和适用场景 •分区表的类型和原理.优点和缺点.适用场景 •表字段的高效设计 •sequence的设计 ...