ZOJ 1952( Dijkstra )要求卡车的最大载货量,即是求dist[]的最小值这里关键是把字符串转化为数字存储在邻接矩阵cost[][]中.开始看了党姐的代码不懂,又看了一遍,大悟!...

 1 #include<stdio.h>
2 #include<stdlib.h>
3 #include<string.h>
4 #define MAX 90000000
5
6 int count = 0;
7 char name[201][40];
8 int find(char *a) //此函数实现将字符串转化为数字,剽窃党姐的呵呵>_<
9 {
10 int i;
11 for( i = 1; i <= count; i++ )
12 if( strcmp(a,name[i]) == 0 )
13 return i;
14 count = i;
15 strcpy(name[i],a);
16 return i;
17 }
18
19 int main()
20 {
21 int n, r, l, s[201], dist[201], cost[201][201];
22 char a[40], b[40];
23 int i, j, start, end, now, k=1;
24 int temp, max, from, to;
25
26 while(scanf("%d%d",&n,&r) != EOF)
27 {
28 if (n==0 && r==0) break;
29 for(i=1; i<=n; i++)
30 {
31 dist[i] = 0;
32 s[i] = 0;
33 for(j=1; j<=n; j++)
34 {
35 cost[i][j] = 0;
36 }
37 }
38 for(i=1; i<=r; i++)
39 {
40 scanf("%s%s",a,b);
41 from = find(a);
42 to = find(b);
43 scanf("%d",&l);
44 cost[from][to] = cost[to][from] = l;
45 }
46 scanf("%s%s",a,b);
47 start = find(a);
48 end = find(b);
49
50 now = start;
51 dist[now] = MAX;
52 s[now] = 1;
53 for(i=1; i<n; i++)
54 {
55 max = -1;
56 for(j=1; j<=n; j++)
57 {
58 if (s[j] == 0)
59 temp = dist[now]<cost[now][j] ? dist[now]:cost[now][j];
60 if(dist[j] < temp)
61 dist[j] = temp;
62 }
63 for(j=1; j<=n; j++)
64 if(s[j]==0 && dist[j] > max)
65 {
66 now = j;
67 max = dist[now];
68 }
69 s[now] = 1;
70 }
71 printf("Scenario #%d\n",k++);
72 printf("%d tons\n\n",dist[end]);
73 }
74 return 0;
75 }
76

转载于:https://www.cnblogs.com/cn19901203/archive/2011/10/19/2217842.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
将RSA公钥表示成字符串的形式,在进行加密时需要先将其转换成公钥结构体类型,然后再使用mbedtls库提供的接口进行加密。 以下是一个示例代码,假设公钥数据已经以字符串的形式存储在`public_key_str`: ```c #include "mbedtls/rsa.h" #include "mbedtls/pk.h" // RSA公钥字符串 const char *public_key_str = "-----BEGIN PUBLIC KEY-----\n" "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAw7Yj9RbqL6pG9Sv3GnZg\n" "h0T3Wz5c0XeX5G8tF/NVbzXUEDRqOZkdt3jv5+0fV5hX6gDZGxhW2k6B9GjPf4XQ\n" "TFYFhCjG5+Y2u4kR7BF0/3KzVcDKMxYmKo7rj2y5OvI5u5zPj6VhKRMoV9JNv5oM\n" "gGpZoF2LwRjuzl7a2MfPZz3+J8+htnLWlVwJyvGn1+sIi3rY9yjV9I6X1hPcqKb8\n" "0KaD0B20qRb4H7rG9yf9FwK7DcC+Zf9jJv4nI8UvRhQ/2zOj9fvy/1aRDN3qQ3Sf\n" "cLJ7fW1dK2RzB5E5XfJZkJwvZVfLHt/1QZGjz5QIg4sB9Xc2zQXmZL+LwN0CF0k+\n" "iwIDAQAB\n" "-----END PUBLIC KEY-----\n"; // 加密函数 int rsa_encrypt(const unsigned char *input, size_t ilen, unsigned char *output, size_t *olen) { int ret = 0; mbedtls_pk_context pk; mbedtls_rsa_context *rsa = NULL; // 初始化公钥结构体 mbedtls_pk_init(&pk); // 解析公钥字符串,填充到公钥结构体 ret = mbedtls_pk_parse_public_key(&pk, (const unsigned char *)public_key_str, strlen(public_key_str) + 1); if (ret != 0) { mbedtls_pk_free(&pk); return ret; } // 获取RSA公钥结构体 rsa = mbedtls_pk_rsa(pk); if (rsa == NULL) { mbedtls_pk_free(&pk); return MBEDTLS_ERR_RSA_BAD_INPUT_DATA; } // 进行加密操作 ret = mbedtls_rsa_pkcs1_encrypt(rsa, NULL, NULL, MBEDTLS_RSA_PUBLIC, ilen, input, output); if (ret != 0) { mbedtls_pk_free(&pk); return ret; } // 获取输出数据长度 *olen = mbedtls_rsa_get_len(rsa); // 释放资源 mbedtls_pk_free(&pk); return 0; } // 主函数 int main(void) { unsigned char input[] = "Hello, world!"; unsigned char output[256] = {0}; size_t olen = 0; int ret = 0; // RSA加密 ret = rsa_encrypt(input, sizeof(input) - 1, output, &olen); if (ret != 0) { printf("RSA encrypt error: %d\n", ret); return ret; } // 输出加密结果 printf("Encrypted message: "); for (size_t i = 0; i < olen; i++) { printf("%02X ", output[i]); } printf("\n"); return 0; } ``` 在上述代码,`rsa_encrypt`函数用于进行RSA加密,输入数据为`input`,输入数据长度为`ilen`,输出数据为`output`,输出数据长度为`olen`。`main`函数,调用`rsa_encrypt`函数进行加密,将加密结果输出到控制台上。 需要注意的是,在进行加密操作时,需要对输出缓冲区进行合适的大小分配。在上述代码,输出缓冲区的大小为256字节,这个大小需要根据加密数据的长度和RSA密钥长度来进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值