A-链接:https://www.nowcoder.com/acm/contest/133/A
来源:牛客网

题目描述

现在有一棵被Samsara-Karma染了k种颜色的树,每种颜色有着不同的价值
Applese觉得Samsara-Karma染的太难看了,于是打算把整棵树重新染成同一种颜色
但是,由于一些奥妙重重的原因,每一次染色Applese可以选择两个有边相连的点,将其中一个染成另一个的颜色。而进行一次这样的操作需要付出两种颜色价值和的代价
现在,Applese的钱要用来买书(game),所以他想要最小化代价

输入描述:

输入包括若干行
第一行包括一个数n,表示这棵树有n个节点
第二行包括n个数,第i个数表示第i个节点的颜色col

i

**注意:一个颜色的标号即价值
接下来的n - 1行,每行包括两个数u, v,表示u节点与v节点之间有一条无向边
n ≤ 100000, 1 ≤ coli ≤ 1e9,数据保证是一棵树

输出描述:

输出包括一行
第一行包括一个数,表示最小代价

输入例子:
4
2 3 4 3
1 2
2 3
3 4
输出例子:
12

-->

示例1

输入

复制

4
2 3 4 3
1 2
2 3
3 4

输出

复制

12
边的输入根本就是多余的,直接枚举所有颜色统计最小的值即可。
  
 #include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 0x3f3f3f3f3f3f3f
int col[];
map<int,int>M;
int main(){
int n,m,i,j,k;
while(cin>>n){ll u,v,tot=,all=;
M.clear();
for(i=;i<=n;++i) {
scanf("%d",col+i);
all+=col[i];
M[col[i]]++;
}
for(i=;i<n;++i){
scanf("%d%d",&u,&v);
}
ll ans=inf;
for(i=;i<=n;++i){
ll tt=M[col[i]];
ans=min(ans,((ll)n-tt)*col[i]+all-tt*col[i]);
}
cout<<ans<<endl;
}
return ;
}
B-链接:https://www.nowcoder.com/acm/contest/133/B
来源:牛客网

题目描述


Applese有1个容量为v的背包,有n个物品,每一个物品有一个价值ai,以及一个大小bi
然后他对此提出了自己的疑问,如果我不要装的物品装的价值最大,只是一定需要装m个物品,要使得求出来的物品价值的中位数最大
Applese觉得这个题依然太菜,于是他把这个问题丢给了你
当物品数量为偶数时,中位数即中间两个物品的价值的平均值

输入描述:

第一行三个数v, n, m,分别代表背包容量,物品数量以及需要取出的物品数量
接下来n行,每行两个数ai,bi,分别代表物品价值以及大小
n ≤ 1e5, 1 ≤ m ≤ n, ai ≤ 1e9, v ≤ 1e9, bi ≤ v

输出描述:

仅一行,代表最大的中位数

输入例子:
20 5 3
3 5
5 6
8 7
10 6
15 10
输出例子:
8

-->

示例1

输入

复制

20 5 3
3 5
5 6
8 7
10 6
15 10

输出

复制

8
非常操蛋,因为我把m打成了n,把first打成了second导致debug了一天,浪费很久的时间= =
做法并不难想,将物品分成前,中,后三个部分且每一部分的长度都知道,然后预处理下前/后最小的体积值,
枚举中间的1/2个点,对于奇数长度,直接枚举中点。偶数长度,枚举第一个点,二分查找右边一个的点(之所以能二分是因为first递增
而且rs[]也是递增的),在满足总的体积不超v的情况下使得价值尽可能的大,也就等价于尽可能的找右边的点。
 #include<bits/stdc++.h>
using namespace std;
#define LL long long
#define pii pair<LL,LL> pii x[];
LL ls[],rs[];
priority_queue<LL>q;
priority_queue<LL>q2; void init(int n,int m){ int ll=(m-)/,rr=(m-)/;
LL sum=;
for(int i=;i<=ll;++i){
q.push(x[i].second);
sum+=x[i].second;
}
ls[ll]=sum;
for(int i=+ll;i<=n;++i){
if(q.empty()) continue;
if(/*!q.empty()&&*/q.top()>x[i].second){
sum=sum-q.top()+x[i].second;
q.pop();
q.push(x[i].second);
}
ls[i]=sum;
} sum=;
for(int i=n;i>n-rr;--i){
q2.push(x[i].second);
sum+=x[i].second;
}
rs[n-rr+]=sum;
for(int i=n-rr;i>=;--i){
if(!q2.empty()&&q2.top()>x[i].second){
sum=sum-q2.top()+x[i].second;
q2.pop();
q2.push(x[i].second);
}
rs[i]=sum;
}
}
int main(){
int n,m,i,j,k;
LL v;
cin>>v>>n>>m;
for(i=;i<=n;++i) scanf("%lld%lld",&x[i].first,&x[i].second);
sort(x+,x++n);
init(n,m);
int ll=(m-)/,rr=(m-)/;
if(m%){
LL ans=;
for(i=n-rr;i>ll;--i){
if(ls[i-]+rs[i+]+x[i].second<=v)
{ans=x[i].first;break;}
}
cout<<ans<<endl;
}
else{
LL ans=;
for(i=ll+;i<n-rr;++i){
int L=i+,R=n;
LL tmp=v-ls[i-]-x[i].second;
while(L<R){
int mid=R-((R-L)>>);
if(n-(mid+)+>=rr&&x[mid].second+rs[mid+]<=tmp) L=mid;
else R=mid-;
}
if(tmp-x[L].second-rs[L+]>=&&n-(L+)+>=rr)
ans=max(ans,x[i].first+x[L].first);
}
cout<<ans/<<endl;
} return ;
}
 

Wannafly挑战赛20-A,B的更多相关文章

  1. 染色 Wannafly挑战赛20 A 思维

    链接:https://www.nowcoder.com/acm/contest/133/A来源:牛客网 现在有一棵被Samsara-Karma染了k种颜色的树,每种颜色有着不同的价值 Applese觉 ...

  2. nowcoder牛客wannafly挑战赛20

    A---染色 签到题,设最终颜色为x,一次操作就需要把一个不是x的点变为x,所以最终颜色为x时需要操作 总结点个数-颜色为x的节点个数,然后枚举所有颜色就行了 #include <iostrea ...

  3. Wannafly 挑战赛 19 参考题解

    这一次的 Wannafly 挑战赛题目是我出的,除了第一题,剩余的题目好像对大部分算法竞赛者来说好像都不是特别友好,但是个人感觉题目质量还是过得去的,下面是题目链接以及题解. [题目链接] Wanna ...

  4. 【Wannafly挑战赛4】F 线路规划 倍增+Kruskal+归并

    [Wannafly挑战赛4]F 线路规划 题目描述 Q国的监察院是一个神秘的组织.这个组织掌握了整个帝国的地下力量,监察着Q国的每一个人.监察院一共有N个成员,每一个成员都有且仅有1个直接上司,而他只 ...

  5. Wannafly挑战赛25游记

    Wannafly挑战赛25游记 A - 因子 题目大意: 令\(x=n!(n\le10^{12})\),给定一大于\(1\)的正整数\(p(p\le10000)\)求一个\(k\)使得\(p^k|x\ ...

  6. Wannafly挑战赛27

    Wannafly挑战赛27 我打的第一场$Wannafly$是第25场,$T2$竟然出了一个几何题?而且还把我好不容易升上绿的$Rating$又降回了蓝名...之后再不敢打$Wannafly$了. 由 ...

  7. Wannafly挑战赛21A

    题目链接 Wannafly挑战赛21A 题解 代码 #include <cstdio> #include <cmath> #define MAX 1000005 #define ...

  8. Wannafly挑战赛24游记

    Wannafly挑战赛24游记 A - 石子游戏 题目大意: A和B两人玩游戏,总共有\(n(n\le10^4)\)堆石子,轮流进行一些操作,不能进行下去的人则输掉这局游戏.操作包含以下两种: 把石子 ...

  9. Wannafly挑战赛25C 期望操作数

    Wannafly挑战赛25C 期望操作数 简单题啦 \(f[i]=\frac{\sum_{j<=i}f[j]}{i}+1\) \(f[i]=\frac{f[i]}{i}+\frac{\sum_{ ...

  10. Wannafly挑战赛18B 随机数

    Wannafly挑战赛18B 随机数 设\(f_i\)表示生成\(i\)个数有奇数个1的概率. 那么显而易见的递推式:\(f_i=p(1-f_{i-1})+(1-p)f_{i-1}=(1-2p)f_{ ...

随机推荐

  1. javashop技术培训总结,架构介绍,Eop核心机制

    javashop技术培训一.架构介绍1.Eop核心机制,基于spring的模板引擎.组件机制.上下文管理.数据库操作模板引擎负责站点页面的解析与展示组件机制使得可以在不改变核心代码的情况下实现对应用核 ...

  2. 解析分布式锁之Zookeeper实现(一)

    实现分布式锁目前有三种流行方案,分别为基于数据库.Redis.Zookeeper的方案,本文主要阐述基于Zookeeper的分布式锁,其他两种会在后文中一起探讨.现在我们来看下使用Zookeeper如 ...

  3. Java 实现后缀xls文件读取

    Java 实现后缀xls文件读取 一.开发环境 poi采用的3.9版本 + JDK1.6 + Myeclipse 二,JAR包 三.实现代码 实体类:UserRoleBean package nc.x ...

  4. 20145306 张文锦 网络攻防 web基础

    20145306 网络攻防 web基础 实验内容 WebServer:掌握Apache启停配置修改(如监听端口)前端编程:熟悉HTML+JavaScript.了解表单的概念编写不同的HTML网页,放入 ...

  5. 20145317彭垚《网络对抗》Exp7 网络欺诈技术防范

    20145317彭垚<网络对抗>Exp7 网络欺诈技术防范 基础问题回答 通常在什么场景下容易受到DNS spoof攻击? 在同一局域网下比较容易受到DNS spoof攻击,攻击者可以冒充 ...

  6. 2018-2019-1 20189218《Linux内核原理与分析》第八周作业

    编译链接的过程 编译就是把文本形式源代码翻译为机器语言形式的目标文件过程. 链接是把目标文件.操作系统的启动代码和用到的库文件进行组织最终形成可执行代码的过程. 对于GCC来说,编译源代码并最终形成可 ...

  7. UVa 714 Copying Books - 二分答案

    求使最大值最小,可以想到二分答案. 然后再根据题目意思乱搞一下,按要求输出斜杠(这道题觉得就这一个地方难). Code /** * UVa * Problem#12627 * Accepted * T ...

  8. soapUi在调用过程中日期参数

    中间加个T 2012-11-05T16:38:30 相关描述:

  9. ubuntu搭建discuz论坛

    a.安装mysql database 1.安装mysql服务端 sudo apt-get install mysql-server  (在此过程中要求为mysql的root用户设置一个密码) 2.安装 ...

  10. C#学习笔记(十六):索引器和重载运算符

    二维数组如何映射到一维数组 重载运算符 1.算术运算符 2.关系运算符, < 和 > 成对重载 using System; using System.Collections.Generic ...