luogu p1119 灾后重建

luogu p1119 灾后重建
少用memset(),不然吃亏在后边。
在floyd在如果有些点不能走,等价于它们不能作中转点,这样就满足了时效性,也就满足了在变化的图中求任意两点的最短路

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<queue>
 4 #include<algorithm>
 5 #include<cmath>
 6 #include<ctime>
 7 #include<set>
 8 #include<map>
 9 #include<stack>
10 #include<cstring>
11 #define inf 2147483647
12 #define ls rt<<1
13 #define rs rt<<1|1
14 #define lson ls,nl,mid,l,r
15 #define rson rs,mid+1,nr,l,r
16 #define N 100010
17 #define For(i,a,b) for(long long i=a;i<=b;i++)
18 #define p(a) putchar(a)
19 #define g() getchar()
20 
21 using namespace std;
22 
23 long long f[310][310];
24 long long n,m,x,y,c;
25 long long t[500100];
26 long long k,q;
27 
28 void in(long long &x){
29     long long y=1;
30     char c=g();x=0;
31     while(c<'0'||c>'9'){
32         if(c=='-')y=-1;
33         c=g();
34     }
35     while(c<='9'&&c>='0'){
36         x=(x<<1)+(x<<3)+c-'0';c=g();
37     }
38     x*=y;
39 }
40 void o(long long x){
41     if(x<0){
42         p('-');
43         x=-x;
44     }
45     if(x>9)o(x/10);
46     p(x%10+'0');
47 }
48 int main(){
49     in(n);in(m);
50      For(i,0,n)
51          For(j,0,n)
52              f[i][j]=inf;
53          
54      For(i,0,n)
55          t[i]=inf;
56     For(i,0,n-1)
57         in(t[i]);
58     For(i,1,m){
59         in(x);in(y);in(f[x][y]);
60         f[y][x]=f[x][y];
61     }
62     For(i,0,n-1)
63         f[i][i]=0;
64 
65     in(q);
66 
67     For(ii,1,q){
68         in(x);in(y);in(c);
69         while(t[k]<=c){
70             For(i,0,n-1)
71                 For(j,0,n-1)
72                     f[i][j]=min(f[i][j],f[i][k]+f[k][j]);
73             k++;
74         }
75         if(f[x][y]==inf||t[x]>c||t[y]>c)
76             o(-1);
77         else
78             o(f[x][y]);
79         p('\n');
80     }
81     return 0;
82 }
View Code

 

转载于:https://www.cnblogs.com/war1111/p/10322762.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Java中连接Kepserver OPC UA加密,首先需要确保你的Java项目中已经导入了支持OPC UA的相关库文件。然后,可以按照以下步骤进行连接: 1. 创建一个OPC UA TCP连接的URL地址,地址格式为:opc.tcp://{服务器IP}:{端口号}。在这个URL中,需要将服务器的IP地址和端口号替换为实际的Kepserver服务器地址和端口号。 2. 使用创建的URL地址创建一个OPC UA的连接对象,使用`new UaTcpClient(url)`方法来创建,其中`url`为上一步创建的URL地址。 3. 在连接对象上调用`setSecurityPolicy`方法来设置安全策略,常用的策略有`SecurityPolicy.SuchAsBasic128Rsa15`和`SecurityPolicy.SuchAsBasic256`。根据实际情况选择合适的安全策略。 4. 设置用户凭证,如果Kepserver服务器设置了用户名和密码,可以通过调用连接对象的`setUserIdentity`方法来设置用户凭证,示例代码如下: ```java UsernameProviderImpl usernameProvider = new UsernameProviderImpl(username, password); client.setUserIdentityProvider(usernameProvider); ``` 其中`UsernameProviderImpl`是自定义的类,实现了`UserIdentityProvider`接口,用于提供用户名和密码。 5. 连接Kepserver服务器,调用连接对象的`connect`方法来建立连接,示例代码如下: ```java client.connect().get(); ``` 其中`get`方法是为了等待连接结果,如果连接成功,则会返回`CompletableFuture`对象,可以通过调用`get`方法来判断连接是否成功。 至此,你已经成功使用Java连接到了Kepserver OPC UA加密服务器。接下来,你可以使用OPC UA客户端API来读取、写入和订阅服务器上的数据了。 请注意,以上步骤仅为示例,实际使用时可能需要根据具体情况进行适当调整。 ### 回答2: Java可以通过使用OPC-UA库来连接Kepserver OPC-UA加密。首先,需要在项目中添加OPC-UA库的依赖。然后,在Java代码中创建一个OPC-UA连接对象,配置连接参数,并使用正确的地址和端口连接Kepserver OPC-UA服务器。 连接Kepserver OPC-UA服务器时,需要注意以下几点: 1. 确保Kepserver OPC-UA服务器已启用加密功能,并配置了正确的安全策略。 2. 在Java代码中,需要使用正确的加密算法和密钥长度来配置安全策略。 3. 客户端和服务器之间的证书验证也是关键。需要正确配置服务器的证书,并在Java代码中导入和配置客户端的证书,以便双方能够互相验证身份。 4. 在Java代码中,使用正确的用户名和密码进行身份验证,以及授权访问服务器的操作。 完成上述步骤后,您可以使用Java代码来读取和写入Kepserver OPC-UA服务器上的变量和标签。通过从服务器读取加密配置息,并在Java代码中正确设置加密参数,您可以确保通过加密通连接Kepserver OPC-UA服务器,保护数据的安全性和机密性。 ### 回答3: Java 连接 KepServer OPC UA 加密的步骤如下。 1. 首先,需要使用 Java 的 OPC UA SDK 来创建一个 OPC UA 客户端。你可以选择一些开源的 SDK,比如 Eclipse Milo 或者 Prosys OPC UA Java SDK。 2. 在 Java 代码中,你需要导入相应的 SDK,以及其他必要的类库和依赖项。 3. 配置客户端连接参数,包括 KepServer 的 IP 地址、端口号和加密设置。通常情况下,KepServer 在默认情况下是不启用加密的,所以你需要先在 KepServer 的配置文件中启用加密功能。启用加密功能后,你需要提供相应的证书和密钥,以及声明要使用的加密算法。 4. 在 Java 代码中,使用 OPC UA SDK 提供的 API 创建一个 OPC UA 客户端对象,并使用配置好的连接参数初始化该对象。 5. 连接KepServer使用客户端对象的连接方法进行连接。在连接过程中,客户端会将之前配置的加密息发送给 KepServer,以便建立一个安全的加密连接。 6. 连接成功后,你可以使用客户端对象的方法来读取和写入 KepServer 上的 OPC UA 变量值。你可以使用节点 ID 或者节点名称来指定要读取和写入的变量。 7. 当你完成所有的操作后,使用客户端对象的断开连接方法来断开连接。 总结:要在Java代码中连接KepServer的加密的OPC UA服务,首先需要使用相应的SDK创建一个OPC UA客户端对象,并设置连接参数以启用加密功能。然后使用该客户端对象连接KepServer,并使用其提供的方法进行数据读取和写入等操作。最后,在完成所有操作后断开连接
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值