P8247 皇室战争
题目描述
训练场可以看作成一个 n×mn \times mn×m 的字符矩阵,每个单元为S,K或.。
S为神箭游侠,K为骷髅。众所周知,神箭游侠的箭是可以穿透的。(我们把他的箭的射程看作是一条射线,且无限长)。由于骷髅很脆,所以打一下就死。已知骷髅都不会动,问你他最少射几箭才能使所有的骷髅都死亡?
假设所有的人物都站在点上,且无限小。
输入格式
第 1 行 2 个数,nnn 和 mmm。
第 2 至第 n+1n+1n+1 行,每行 mmm 个字符,代表骷髅K,空地.和神箭游侠S,神箭游侠只会有一个。
输出格式
一个数,即最少射的箭数。
输入输出样例 #1
输入 #1
3 5
K...K
.K.K.
..S..
输出 #1
2
输入输出样例 #2
输入 #2
3 5
KKKKK
KKSKK
KKKKK
输出 #2
12
说明/提示
- Subtask 1(15 分):1≤n,m≤101 \le n,m \le 101≤n,m≤10;
- Subtask 2(20 分):1≤n,m≤4001 \le n,m \le 4001≤n,m≤400;
- Subtask 3(35 分):1≤n,m≤1031 \le n,m \le 10^31≤n,m≤103;
- Subtask 4(30 分):1≤n×m≤1061 \le n\times m \le 10^61≤n×m≤106。
n,mn,mn,m 均为正整数。
样例 111 解释:

C++实现
#include<bits/stdc++.h>//万能头YYDS
using namespace std;
map<pair<int,int>,bool>mp;
int n,m,sx,sy;
char c;
queue<pair<int,int> >kulou;
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>c;
if(c=='K') kulou.push(make_pair(i,j));
if(c=='S') sx=i,sy=j;
}
}
while(!kulou.empty()){
int tx=kulou.front().first,ty=kulou.front().second;
kulou.pop();
tx-=sx;
ty-=sy;
int g=abs(__gcd(tx,ty));
tx/=g;//化简比
ty/=g;//化简比
mp[make_pair(tx,ty)]=true;
}
cout<<mp.size();
return 0;
}

后续
接下来我会不断用C++来实现信奥比赛中的算法题、GESP考级编程题实现、白名单赛事考题实现,记录日常的编程生活、比赛心得,感兴趣的请关注,我后续将继续分享相关内容
用C++实现信奥 P8247 皇室战争&spm=1001.2101.3001.5002&articleId=149459527&d=1&t=3&u=85fdd8669e254caf9bc4b404a41940bd)
1399

被折叠的 条评论
为什么被折叠?



