HDU6095——Rikka with Competition

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6095

题目意思:抱歉虽然是签到题,现场真的没做出来,因为题目没看懂,题目说明现在给出n个选手的能力值,现在举办n-1场比赛,如果每场比赛中选出的两名选手之间能力的差大于k,则能力高的人获胜,否则两个人都获胜,问最后有多少人获胜了。(注:如果他如果有人可以击败他,则就不算获胜)

代码:从代码里面我们看出,先对n个选手的能力值排序,然后ct=1,然后从大到小两两相邻比较。如果有一组相邻的差大于k,则说明前面的所有选手都会被击败,获胜的人就是当前ct的值,否则ct++。

 //Author: xiaowuga
#include <iostream>
#include <algorithm>
#include <set>
#include <vector>
#include <queue>
#include <cmath>
#include <cstring>
#include <cstdio>
#include <ctime>
#include <map>
#include <bitset>
#include <cctype>
#define maxx INT_MAX
#define minn INT_MIN
#define inf 0x3f3f3f3f
#define mem(s,ch) memset(s,ch,sizeof(s))
#define nc cout<<"nc"<<endl
#define sp " "
const long long N=;
using namespace std;
typedef long long LL;
typedef int II;
int main() {
ios::sync_with_stdio(false);cin.tie();
II T;
II a[N];
cin>>T;
while(T--){
II n,k;
cin>>n>>k;
for(II i=;i<n;i++) cin>>a[i];
sort(a,a+n);
II ct=;
for(II i=n-;i>=;i--){
if(a[i]-a[i-]<=k) ct++;
else break;
}
cout<<ct<<endl;
}
return ;
}

HDU6090——Rikka with Graph

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6090

题目意思:给出n个点,m条边,构成一个无向图,使得任意两个点之间的之间的距离之和,两个联通的点之间距离等于他们之间需要经过的边数,两个不连通的点之间的距离是n,求这个距离和的最小值。

思路:首先明确一点可以联通的两个点之间的距离要么是1,要么是2,我也不知道怎么说,反正就是xjb贪心,我们思考一个问题如果m==n-1,那么刚好是一棵树,这个时候最小的距离一定是形成一棵一个根连着n-1个点的数。我们根据这一点分成以下这四种情况

1.n*(n-1)/2<=m:这种情况下,m的数量足以形成一个完全图。

2.m>n-1&&m<n*(n-1)/2:这种情况下,足以形成一棵树,但是不足以形成一个完全图。

3.m==n-1:这种情况下刚好形成一棵树

4.m<n-1:这种情况下不够形成一棵树,我们可肯定在边够的范围内先构造一个树,剩下的之间距离是n,xjb往上加就好了。

代码:

 //Author: xiaowuga
#include <iostream>
#include <algorithm>
#include <set>
#include <vector>
#include <queue>
#include <cmath>
#include <cstring>
#include <cstdio>
#include <ctime>
#include <map>
#include <bitset>
#include <cctype>
#define maxx INT_MAX
#define minn INT_MIN
#define inf 0x3f3f3f3f
#define mem(s,ch) memset(s,ch,sizeof(s))
#define nc cout<<"nc"<<endl
#define sp " "
const long long N=;
using namespace std;
typedef long long LL;
typedef int II;
int main() {
ios::sync_with_stdio(false);cin.tie();
LL n,m;
II T;
cin>>T;
while(T--){
cin>>n>>m;
if(n*(n-)/<=m){
cout<<n*(n-)<<endl;
}
else if(m>n-&&m<n*(n-)/){
cout<<(+*(n-))*(n-)-(m-n+)*<<endl;
}
else if(m==n-){
cout<<(+*(n-))*(n-)<<endl;
}
else if(m<n-){
LL p=m+;
LL q=n-p;
cout<<(+*(p-))*(p-)+p*q*n*+q*(q-)*n<<endl;
}
}
return ;
}

HDU6092——Rikka with Subset

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6092

题目意思:给出n,m,n表示A数组元素的数量,m表示A数组的元素之和,给出一个B数组,下标从0-m,代表原来A数组(具有n个数)中和为i(代表B数组中的下标)的子集数量,现在要还原A数组,将A数组的元素从小到大输出。

思路:比赛的时候没想出来,看了题解说是一个反向背包,于是反向推了一下。我们假设A数组的第i个是x,那么对于B数组的影响就是所有 B[i]都增加了B[i-x],表示原来集合和等于i-x的因为多了A中的第i个数x,使得集合和为i的数量怎么加了原来B数组中B[i-x]的数量。然后我们想当与反向推,就像题解里面说的每次对于A数组中的每一个数,我们都把B数组从1扫到m,发现的第一个不等于0的数就是,就是当前剩余的元素里面最小的一项,具体看代码吧!

代码:

 //Author: xiaowuga
#include <iostream>
#include <algorithm>
#include <set>
#include <vector>
#include <queue>
#include <cmath>
#include <cstring>
#include <cstdio>
#include <ctime>
#include <map>
#include <bitset>
#include <cctype>
#define maxx INT_MAX
#define minn INT_MIN
#define inf 0x3f3f3f3f
#define mem(s,ch) memset(s,ch,sizeof(s))
#define nc cout<<"nc"<<endl
#define sp " "
const long long N=;
using namespace std;
typedef long long LL;
typedef int II;
LL n,m;
LL B[N];
LL ans[N];
int main() {
ios::sync_with_stdio(false);cin.tie();
II T;
cin>>T;
while(T--){
cin>>n>>m;
mem(B,);
mem(ans,);
for(II i=;i<=m;i++) cin>>B[i];
for(II i=;i<=n;i++){
for(II j=;j<=m;j++){
if(B[j]!=){
ans[i]=j;
for(II k=j;k<=m;k++){
B[k]-=B[k-j];
}
break;
}
}
}
int flag=;
sort(ans+,ans++n);
for(II i=;i<=n;i++){
if(flag){ cout<<ans[i];flag=;}
else cout<<" "<<ans[i];
}
cout<<endl;
}
return ;
}

2017 Multi-University Training Contest - Team 5——HDU6095&&HDU6090&&HDU的更多相关文章

  1. 2017 Multi-University Training Contest - Team 9 1005&&HDU 6165 FFF at Valentine【强联通缩点+拓扑排序】

    FFF at Valentine Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  2. 2017 Multi-University Training Contest - Team 9 1004&&HDU 6164 Dying Light【数学+模拟】

    Dying Light Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Tot ...

  3. 2017 Multi-University Training Contest - Team 9 1003&&HDU 6163 CSGO【计算几何】

    CSGO Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Subm ...

  4. 2017 Multi-University Training Contest - Team 9 1002&&HDU 6162 Ch’s gift【树链部分+线段树】

    Ch’s gift Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total S ...

  5. 2017 Multi-University Training Contest - Team 9 1001&&HDU 6161 Big binary tree【树形dp+hash】

    Big binary tree Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)T ...

  6. 2017 Multi-University Training Contest - Team 1 1003&&HDU 6035 Colorful Tree【树形dp】

    Colorful Tree Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

  7. 2017 Multi-University Training Contest - Team 1 1006&&HDU 6038 Function【DFS+数论】

    Function Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Total ...

  8. 2017 Multi-University Training Contest - Team 1 1002&&HDU 6034 Balala Power!【字符串,贪心+排序】

    Balala Power! Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

  9. 2017 Multi-University Training Contest - Team 1 1011&&HDU 6043 KazaQ's Socks【规律题,数学,水】

    KazaQ's Socks Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

随机推荐

  1. Struts2初学 Struts2在Action获取内置对象request,session,application(即ServletContext)

    truts2在Action中如何访问request,session,application(即ServletContext)对象???? 方式一:与Servlet API解耦的方式      可以使用 ...

  2. oracle 使用occi方式 批量插入多条数据

    if (vecInfo.empty()) { ; //数据为空,不上传,不上传标志设置为1,只有0表示上传成功 } std::string strUserName = userName; std::s ...

  3. 一款基于HTML5 Canvas的画板涂鸦动画

    今天给各网友分享一款基于HTML5 Canvas的画板涂鸦动画.记得之前我们分享过一款HTML5 Canvas画板工具,可以切换不同的笔刷,功能十分强大.本文今天要再来分享一款基于HTML5 Canv ...

  4. C语言 · 数的读法

    基础练习 数的读法   时间限制:1.0s   内存限制:512.0MB    问题描述 Tom教授正在给研究生讲授一门关于基因的课程,有一件事情让他颇为头疼:一条染色体上有成千上万个碱基对,它们从0 ...

  5. linux udhcpc 后无法自动设置网卡ip

    arm 主板用 udhcpc 获取租赁的空闲的ip后,并没有直接设置在网卡上. 查了一下相关原因,是因为虽然已经获取了ip, 但是并没有通过脚本去设置这个IP. 在 busybox 里面有相关的脚本要 ...

  6. UCOS2系统内核讲述(五)_初始化TCB详情

    Ⅰ.写在前面 学习本文之前可以参看我前面的文章: UCOS2系统内核讲述(四)_创建任务 上一篇文章讲述了关于函数“OSTaskCreateExt”创建任务函数体里面重要一些的内容,本文接着上一张讲述 ...

  7. Android——Activity恢复用户用EditText输入的数据

    说明: 在横屏输入的内容,在Activity销毁后,即横屏后,获取用户输入的内容 步骤: 1.在xml页面定义EditText的id 2.用onSaveInstanceState保存用户输入的数据 ( ...

  8. IDEA 中 右键新建时,没有新建class的解决方案

    今天在用IDEA新建包后,因为我新建的包名是userprivman-data这样的包,然后导致右键后没法新建类,并且在新建包名的时候就提示:不合法的包名,可能不会新建类 然后右键单击包名,发现没有新建 ...

  9. word 操作教程

    http://blog.163.com/haolongqin@126/blog/static/10999842220159993540527/ https://blog.csdn.net/ibigpi ...

  10. Dubbo (开源分布式服务框架)

    Provider 暴露服务方称之为“服务提供者”. Consumer 调用远程服务方称之为“服务消费者”. Registry 服务注册与发现的中心目录服务称之为“服务注册中心”. Monitor 统计 ...