HDU6026 Deleting Edges 2017-05-07 19:30 38人阅读 评论(0) 收藏
Deleting Edges
                                                                                 Time Limit: 2000/1000 MS (Java/Others)    Memory
 Limit: 131072/131072 K (Java/Others)
                                                                                                                 Total Submission(s): 18    Accepted Submission(s): 9
There is a bi-directional graph with n nodes,
labeled from 0 to n−1.
Every edge has its length, which is a positive integer ranged from 1 to 9.
Now, Little Q wants to delete some edges (or delete nothing) in the graph to get a new graph, which satisfies the following requirements:
(1) The new graph is a tree with n−1 edges.
(2) For every vertice v(0<v<n),
the distance between 0 and v on
the tree is equal to the length of shortest path from 0 to v in
the original graph.
Little Q wonders the number of ways to delete edges to get such a satisfied graph. If there exists an edge between two nodes i and j,
while in another graph there isn't such edge, then we regard the two graphs different.
Since the answer may be very large, please print the answer modulo 109+7.
In each test case, the first line contains an integer n(1≤n≤50),
denoting the number of nodes in the graph.
In the following n lines,
every line contains a string with n characters.
These strings describes the adjacency matrix of the graph. Suppose the j-th
number of the i-th
line is c(0≤c≤9),
if c is
a positive integer, there is an edge between i and j with
length of c,
if c=0,
then there isn't any edge between i and j.
The input data ensure that the i-th
number of the i-th
line is always 0, and the j-th
number of the i-th
line is always equal to the i-th
number of the j-th
line.
2
01
10
4
0123
1012
2101
3210
1
6
#include <iostream>
#include <cstdio>
#include <cstring>
#include <string>
#include <algorithm>
#include <cmath>
#include <map>
#include <cmath>
#include <set>
#include <stack>
#include <queue>
#include <vector>
#include <bitset>
#include <functional> using namespace std; #define LL long long
const int INF=0x3f3f3f3f;
const int mod=1e9+7; int n,m;
int mp[55][55];
int dis[55];
int vis[55];
LL cnt[55];
struct node
{
int id,val;
friend bool operator<(node a,node b)
{
return a.val>b.val;
}
}; void djstl(int o)
{
memset(dis,INF,sizeof dis);
memset(vis,0,sizeof vis);
memset(cnt,0,sizeof cnt);
node f,d;
f.id=o,f.val=0;
priority_queue<node>q;
q.push(f);
vis[o]=cnt[o]=1,dis[o]=0;
while(!q.empty())
{
f=q.top();
q.pop();
vis[f.id]=1;
for(int i=0; i<n; i++)
{
if(!vis[i]&&f.val+mp[f.id][i]<dis[i])
{
dis[i]=f.val+mp[f.id][i];
cnt[i]=1;
d.id=i;
d.val=dis[i];
q.push(d);
}
else if(!vis[i]&&f.val+mp[f.id][i]==dis[i])
{
cnt[i]++;
}
}
}
} int main()
{
char s[55];
while(~scanf("%d",&n))
{
memset(mp,INF,sizeof mp);
for(int i=0; i<n; i++)
{
scanf("%s",&s);
for(int j=0; j<n; j++)
if(s[j]!='0')
mp[i][j]=s[j]-'0';
} djstl(0);
LL ans=1;
for(int i=0; i<n; i++)
{
ans*=cnt[i];
ans%=mod;
}
printf("%d\n",ans);
}
return 0;
}
HDU6026 Deleting Edges 2017-05-07 19:30 38人阅读 评论(0) 收藏的更多相关文章
- ZOJ2208 To and Fro                                                                                            2017-04-16 19:30             45人阅读              评论(0)              收藏
		To and Fro Time Limit: 2 Seconds Memory Limit: 65536 KB Mo and Larry have devised a way of encr ... 
- POJ3320 Jessica's Reading Problem                                                                                            2017-05-25 19:55             38人阅读              评论(0)              收藏
		Jessica's Reading Problem Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 12346 Accep ... 
- HDU6023 Automatic Judge                                                                                            2017-05-07 18:30             73人阅读              评论(0)              收藏
		Automatic Judge Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others ... 
- HDU6029 Happy Necklace                                                                                            2017-05-07 19:11             45人阅读              评论(0)              收藏
		Happy Necklace Time Limit: ... 
- HDU6029 Graph Theory                                                                                            2017-05-07 19:04             40人阅读              评论(0)              收藏
		Graph Theory Time Limit: 2000/1000 M ... 
- HDU6027 Easy Summation                                                                                            2017-05-07 19:02             23人阅读              评论(0)              收藏
		Easy Summation Time Limit: 2000/1000 MS ... 
- Network Saboteur                                                       分类:            搜索             POJ             2015-08-09 19:48    7人阅读    评论(0)    收藏
		Network Saboteur Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 10147 Accepted: 4849 Des ... 
- 滑雪                                                       分类:            POJ             2015-07-23 19:48    9人阅读    评论(0)    收藏
		滑雪 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 83276 Accepted: 31159 Description Mich ... 
- 第十二届浙江省大学生程序设计大赛-Lunch Time                                                       分类:            比赛             2015-06-26 14:30    5人阅读    评论(0)    收藏
		Lunch Time Time Limit: 2 Seconds Memory Limit: 65536 KB The 999th Zhejiang Provincial Collegiate Pro ... 
随机推荐
- L2tp协议简单解析
			1.L2TP简介 L2TP(Layer 2 Tunneling Protocol,二层隧道协议)是VPDN(Virtual PrivateDial-up Network,虚拟私有拨号网)隧道协议的一种 ... 
- JS 实现Json查询的方法实例
			其实很简单,我这部分代码,前一部分是简单的实现如何使用JS写模板,第二个就是具体的实现了JSON查询的一个扩展. 以后查询Json就有了利器了. 代码如下: /* * 定义模板函数 ... 
- freemaker基础语法
			1.freemarker中Request,Session的用法:java块:request.getSession().setAttribute("qq","http: ... 
- 机房servlet过滤器
			1.源代码 loginform.html <html> <head> <title>使用过滤器改变请求编码</title> <meta http- ... 
- 吴裕雄 实战PYTHON编程(10)
			import cv2 cv2.namedWindow("frame")cap = cv2.VideoCapture(0)while(cap.isOpened()): ret, im ... 
- HttpClient 4 和 HttpClient 3 超时
			HttpClient 4: 连接超时: httpclient.getParams().setParameter(CoreConnectionPNames.CONNECTION_TIMEOUT,6000 ... 
- WebDriverException: Message: f.QueryInterface is not a function
			WebDriverException: Message: f.QueryInterface is not a function 使用webdriver打开c.highpin.cn,结果报错,见下图: ... 
- vs2010下载Microsoft Visual Studio 2010 Express(vs2010中文版下载)速成官方合集正式版
			http://www.xiazaiba.com/html/1832.html VB.NET 2010 Express: 2KQT8-HV27P-GTTV9-2WBVV-M7X96VC++ 2010 E ... 
- tf.unstack\tf.unstack
			tf.unstack 原型: unstack( value, num=None, axis=0, name='unstack' ) 官方解释:https://tensorflow.google.cn/ ... 
- ios 8 联系人ABPeoplePickerNavigationController
			一. ios 联系人ABPeoplePickerNavigationControllerDelegate方法,新添加下面两个联系人选中方法,适配iOS8需要实现 // Called after a p ... 
