BNUOJ 1037 精神控制
XsuagrX喜欢到处唬人,各种唬。这不,经过刻苦修炼,他终于掌握了Bane Element的Ultra绝技加强版,恶魔掌控(快捷键F)(YY中&……)。当XsugarX对某个人胡言乱语Q@# @时,可以控制这个人的行动,并且被完全控制的人会对其他人继续胡言乱语,但是他们只能控制被胡言乱语的人的部分精神,当满足如下条件时,我们说A控制B:
1、 A控制了B大于等于50%的精神。
2、 A控制了Ci,Ci控制了Bi Di%的精神,而∑Di≧50
有一天他心血来潮对着N个人一通@#Q%#$#后,想知道究竟那些人被其他人控制了。
现在你的任务是读入n组i控制j精神的p%,并输出数对(p,q)表示p控制q。
由于能力有限,XsugarX最多只能控制100个人,且所有人的编号均小于100。
Input
第一行一个数Z表示有Z组测试数据
对于每组测试数据
第一行一个n,表示有n个控制关系。
以下n行,每行一组(i,j,k)表示编号i的人控制编号j的人精神的k%
Output
对于每组数据,输出所有的控制关系,按升序排列,每组答案最后输出一个空行。
Sample Input
1
3
1 2 80
2 3 80
3 1 20
Sample Output
1 2
1 3
2 3 233333有一阵子没写博客了来一发,开学忙着复习苦逼的补考,高数大法坑死人。
这道题零零碎碎搞了一星期,最后才发现题意理解还有问题,这是一个要列加的图,比如两条路单走那个都不通合起来看就通了2333绝对坑。
原来搞错掉的代码也贴过来了关键是第一次摆出容器大干一场。set的反向排序还没搞出来再看看,图搜索的基本想法get。这道题复杂两个二维数组就能搞定,后面是正确代码。
#include<iostream>
#include<cstdio>
#include<vector>
#include<stack>
#include<set>
#include<algorithm>
using namespace std;
struct donser
{
vector <int> son;
vector <int> num;
};
donser d[];
stack <int> dong;
set <int> dongser;
int i,j,k;
int a,b,c,e,p,q,t; void loop(int m)
{
for(vector<int>::iterator iter=d[m].son.begin();iter!=d[m].son.end();iter++)
{
t=dongser.size();
if(*iter==m){continue;}
dongser.insert(*iter);
q=dongser.size();
if(q==t){continue;}
loop(*iter);
} }
int main()
{
freopen("stdin.txt","r",stdin);
while(~scanf("%d",&j))
{
scanf("%d",&k);
for(i=;i<=k;i++)
{
scanf("%d %d %d",&a,&b,&c);
if(c>=){d[a].son.push_back(b);d[a].num.push_back(c);}
}
for(i=;i<=;i++)
{
if(d[i].son.size()==){continue;}
loop(i); set<int>::reverse_iterator j;
for(j=dongser.rbegin();j!=dongser.rend();j++)
{
dong.push(*j); }
while(dong.size()>)
{
printf("%d %d\n",i,dong.top());
dong.pop();
}
dongser.clear();
}
}
return ;
}
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
using namespace std;
int n,t,x,y,num,donser[][];
bool rank,a[][],dong[];
int main()
{
freopen("stdin.txt","r",stdin);
scanf("%d",&t);
while(t--){
scanf("%d",&n);
memset(a,,sizeof(a));
memset(donser,,sizeof(donser));
memset(dong,,sizeof(dong)); while(n--){
scanf("%d%d%d",&x,&y,&num);
donser[x][y] += num;
dong[x] = dong[y] = ;
if(donser[x][y] >= ) a[x][y] = ;
} n = ;
for(int i = ;i <= n;++i) a[i][i] = ;
while(){
rank = ;
for(int i = ;i <= n;++i)
for(int j = ;j <= n;++j){
if(a[i][j]) continue;
num = ;
for(int k = ;k <= n;++k) if(a[i][k]) num += donser[k][j];
if(num >= ) { a[i][j] = ; rank = ; }
}
if(rank) break;
}
for(int i = ;i <= n;++i)
if(dong[i]) for(int j = ;j <= n;++j) if(dong[j] && i != j && a[i][j]) printf("%d %d\n",i,j);
puts("");
}
return ;
}
坑,A掉的代码
BNUOJ 1037 精神控制的更多相关文章
- 【hihoCoder】1037 : 数字三角形
题目:http://hihocoder.com/problemset/problem/1037 一个迷宫有n层,第 i 层有 i 个房间 从第i层的第i个房间(i, i)可以走到第i+1层的第i个房间 ...
- BNUOJ 52325 Increasing or Decreasing 数位dp
传送门:BNUOJ 52325 Increasing or Decreasing题意:求[l,r]非递增和非递减序列的个数思路:数位dp,dp[pos][pre][status] pos:处理到第几位 ...
- 【CodeVS 1037】取数游戏
http://codevs.cn/problem/1037/ Alice必胜是Alice将硬币移向边权为0的一端并且把经过的边变为0,让BoB无路可走. 这样只要起点到两个方向最近的0边权的端点的边数 ...
- bnuoj 24251 Counting Pair
一道简单的规律题,画出二维表将数字分别相加可以发现很明显的对称性 题目链接:http://www.bnuoj.com/v3/problem_show.php?pid=24251 #include< ...
- bnuoj 44359 快来买肉松饼
http://www.bnuoj.com/contest/problem_show.php?pid=44359 快来买肉松饼 Time Limit: 5000 ms Case Time Lim ...
- BNUOJ 1006 Primary Arithmetic
Primary Arithmetic 来源:BNUOJ 1006http://www.bnuoj.com/v3/problem_show.php?pid=1006 当你在小学学习算数的时候,老师会教你 ...
- bnuoj 34985 Elegant String DP+矩阵快速幂
题目链接:http://acm.bnu.edu.cn/bnuoj/problem_show.php?pid=34985 We define a kind of strings as elegant s ...
- 【BZOJ】【1037】【ZJOI2008】生日聚会party
DP orz iwtwiioi 这种题居然是DP……原来统计方案数是可以用动态规划来做的啊= =用一些变量来维护一些信息,保证方案可行性/合法性 人太弱实在是有些忧伤…… /************* ...
- hihocoder 1037 数字三角形
#1037 : 数字三角形 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 问题描述 小Hi和小Ho在经历了螃蟹先生的任务之后被奖励了一次出国旅游的机会,于是他们来到了大洋彼岸 ...
随机推荐
- js遍历json数据
先看看json返回的数据结构: 我需要遍历取出bookreno 与 title 加载到页面容器中去 首先我要取到 recommendedBookList 字典结构数据,然后遍历反射到相应对象 ...
- 第三十课:JSDeferred详解1
本课难度非常大,看一遍,蛋会疼,第二遍蛋不舒服,第三遍应该貌似懂了.初学者莫来,没必要,这完全就是一个研究. JSDeferred是日本高手cho45搞出来的,其易用性远胜于Mochikit Defe ...
- “耐撕”团队 2016.04.11 站立会议
1. 时间 : 19:30--19:50. 共计20分钟. 2. 成员 : Z 郑蕊 * 组长 (博客:http://www.cnblogs.com/zhengrui0452/), P 濮成林(博客: ...
- Daily Scrum – 1/7
Meeting Minutes 搞定了一个bug,单词面板滚动条的bug: 在电脑屏幕上的屏幕适配有了新思路: Progress part 组员 今日工作 Time (h) 明日计划 Time ( ...
- 利用Ant脚本生成war包的详细步骤
使用ant脚本前的准备 1.下载一个ant安装包.如:apache-ant-1.8.4-bin.zip.解压到E盘. 2.配置环境变量.新增ANT_HOME:E:\apache-ant-1.8.4:P ...
- 网站性能工具Yslow的使用方法
Yslow是雅虎开发的基于网页性能分析浏览器插件,从年初我使用了YSlow后,改变了博客模板大量冗余代码,不仅提升了网页的打开速度,这款插件还帮助我分析了不少其他网站的代码,之前我还特意写了提高网站速 ...
- poppin_xpower_ 常城
- Jquery-控制table的奇偶数色列
css代码 <style> .even{background:#FFF38F;} .odd{background:#FFFFEE;} .selected{background:#FF990 ...
- Java编程思想学习(四) 访问权限
几种访问权限修饰词 public,protected,private,friendly(Java中并无该修饰词,即包访问权限,不提供任何访问修饰词) 使用时,放置在类中成员(域或方法)的定义之前的,仅 ...
- 苹果开发者账号如何多人协作进行开发和真机调试XCode
首先,先说明一下,我们最容易误解或者理解错误的是:p12证书. 其实p12证书,最直接的使用就是,我们在一台电脑上生成好了cer证书之后,如果使用了开发者账号(无论公司或者个人的)进行ipa进行打包和 ...