每个测试数据包括 n + m + 2 行。 第 1 行只包含一个整数 n,表示代理服务器的个数。 第 2行至第n + 1行每行是一个字符串,表示代理服务器的 IP地址。这n个 IP地址两两不相同。 第 n + 2 行只包含一个整数 m,表示要访问的服务器的个数。 第 n + 3 行至第 n + m + 2 行每行是一个字符串,表示要访问的服务器的 IP 地址,按照访问的顺序给出。 每个字符串都是合法的IP地址,形式为“xxx.yyy.zzz.www”,其中任何一部分均是0–255之间的整数。输入数据的任何一行都不包含空格字符。 其中,1<=n<=1000,1<=m<=5000。
可能有多组测试数据,对于每组输入数据, 输出数据只有一行,包含一个整数s,表示按照要求访问服务器的过程中切换代理服务器的最少次数。第一次使用的代理服务器不计入切换次数中。若没有符合要求的安排方式,则输出-1。
3 166.111.4.100 162.105.131.113 202.112.128.69 6 72.14.235.104 166.111.4.100 207.46.19.190 202.112.128.69 162.105.131.113 118.214.226.52
1
#include <stdbool.h>
#include <stdio.h>
//想象成你有n种武器去面对m个敌人,每种武器刚好都有一种有对应抗性的敌人,需要换武器应对
//尽量少换武器那当然是,选一个一路打,打得越多越好
//因此从前往后遍历,直到遇到过所有种类抗性的敌人为止,算一个轮回,因为之前的怪物都可以用最后遇到的敌人对应的武器来砍翻。
//O(nm)的复杂度,因为每个怪都要遍历一次武器,看对应哪一把。
//但凡我有两把武器,都不可能打不过,输出-1;因此只有在只有一把武器,且刚好有抗性敌人的时候会失败,输出-1
int main() {
int n, m;
while (scanf("%d", &n) != EOF) {
char procyIP[n][16], temp[16];
bool used[n],flag=false;
int used_count = 0, change_count = 0;
for(int i=0; i<n; i++){
scanf("%s", procyIP[i]);
used[i] = false;
}
scanf("%d", &m);
if(n!=1){
for(int i=0; i<m; i++){
scanf(" %s", temp);
for(int j=0; j<n; j++){ //逐个比对
if(!used[j] && (strcmp(procyIP[j], temp) == 0)){
//这把武器没用过,且刚好遇到抗性怪
used_count++;
if(used_count == n){ //要换武器了
change_count++;
used_count = 1;
for(int k=0; k<n; k++){used[k] = false;}
}
used[j] = true;
break; //剩下的代理不用比了,因为两两不相同
}
}
}
printf("%d\n", change_count);
}else{
for(int i=0; i<m; i++){
scanf("%s", temp);
if(!flag && strcmp(procyIP[0], temp) == 0){ //遇到困难就自杀
printf("-1\n");
flag = true;
}
}
if(!flag){printf("0\n");} //没遇到就神作
}
}
return 0;
}