QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#687473#8236. Snake MoveasitshouldbeRE 0ms0kbC++202.4kb2024-10-29 19:12:162024-10-29 19:12:16

Judging History

你现在查看的是最新测评结果

  • [2024-10-29 19:12:16]
  • 评测
  • 测评结果:RE
  • 用时:0ms
  • 内存:0kb
  • [2024-10-29 19:12:16]
  • 提交

answer

#include <bits/stdc++.h>
// #pragma GCC optimize(2)
#include <iostream>
#include <algorithm>
#include <cstring>
#include <cmath>
#include <queue>
#include <vector>
#include <map>
#include <set>
#include <stack>
#include <unordered_set>
#include <unordered_map>
#define x first
#define y second
#define endl '\n'
#define pi acos(-1.0)
using namespace std;
typedef pair<int, int> PII;
typedef pair<double, int> PDI;
typedef pair<int, PII> PIII;
typedef pair<PII, char> PIIC;
typedef long long LL;
int dx[] = {1, 0, 0, -1, -1, -1, 1, 1}, dy[] = {0, -1, 1, 0, -1, 1, -1, 1};
int mou[] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
const int N = 3e3 + 10, M = 50 + 10, mod = 998244353, INF = 0x3f3f3f3f;
const LL inf=0x3f3f3f3f3f3f3f3f;
const double eps = 1e-8;
int n, m,k, t,body[N][N];
string g[N];
int d[N][N];
bool st[N][N];

bool solve()
{
    priority_queue<PIII,vector<PIII>,greater<PIII>>heap;
    cin>>n>>m>>k;
    for(int i=0;i<n;i++)
        for(int j=0;j<m;j++) d[i][j]=INF;
    for(int i=0;i<k;i++){
        int x,y;cin>>x>>y;
        --x,--y;
        body[x][y]=k-i;
        if(!i){
            d[x][y]=0;
            heap.push({0,{x,y}});
        }
    }
    // for(int i=0;i<n;i++,puts(""))
    //     for(int j=0;j<m;j++) cout<<body[i][j]<<" ";    
    for(int i=0;i<n;i++) cin>>g[i];
    while(heap.size()){
        auto t=heap.top();heap.pop();
        int dis=t.x,x=t.y.x,y=t.y.y;
        if(st[x][y]) continue;
        st[x][y]=1;
        for(int i=0;i<4;i++){
            int a=x+dx[i],b=y+dy[i];
            if(a<0||a>=n||b<0||b>=m||g[a][b]=='#'||st[a][b]) continue;
            if(d[a][b]>max(dis+1,body[a][b])){
                d[a][b]=max(dis+1,body[a][b]);
                heap.push({d[a][b],{a,b}});
            }
        }
    }
    // for(int i=0;i<n;i++,puts(""))
    //     for(int j=0;j<m;j++) cout<<d[i][j]<<" ";
    LL res=0;
    for(int i=0;i<n;i++)
        for(int j=0;j<m;j++)
            if(d[i][j]!=inf) res+=(LL)d[i][j]*d[i][j];
    cout<<res;
}

int main()
{
    //clock_t start,end;//定义clock_t变量
    //start = clock(); 
    ios::sync_with_stdio(false), cin.tie(0), cout.tie(0),cout.precision(10);
    // freopen("in.in","r",stdin);
    // freopen("order.in","w",stdout);
    t = 1; //cin >> t;
    while (t--) solve();
    //end = clock();   //结束时间
    //cout<<"time = "<<double(end-start)/CLOCKS_PER_SEC<<"s"<<endl;
    return 0;
}

详细

Test #1:

score: 0
Runtime Error

input:

4 5 5
3 5
3 4
3 3
3 2
4 2
.....
.....
.....
.....

output:


result: