QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#788844#9623. 合成大西瓜Lonelyper#WA 0ms3756kbC++174.2kb2024-11-27 18:30:122024-11-27 18:30:14

Judging History

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

  • [2024-11-27 18:30:14]
  • 评测
  • 测评结果:WA
  • 用时:0ms
  • 内存:3756kb
  • [2024-11-27 18:30:12]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
void print(vector<int> nums)
{
    for(int x:nums)
    cout<<x<<" ";
    cout<<endl;
}
static int cal3(vector<int> nums)
{
    return max(nums[0],min(nums[1],nums[2]));
}
class meth
{
    public:
    int n;
    vector<vector<int>> edges;
    //vector<int> leaf;
    vector<int> lock;
    vector<int> mark;
    vector<int> status;
    vector<int> nums;
    meth(int sz,vector<vector<int>> raw_edges,vector<int> o_nums):edges(sz),mark(sz,0),status(sz,0),lock(sz,0)
    {
        n=sz;
        nums=o_nums;
        for(auto arr:raw_edges)
        {
        edges[arr[0]].push_back(arr[1]);
        edges[arr[1]].push_back(arr[0]);
        ++lock[arr[0]];
        ++lock[arr[1]];
        }
    }
    void make_status()
    {
        for(int i=0;i<n;++i)
        {
            for(int x:edges[i])
            if(lock[x]==1)
            ++status[i];
        }
    }
    void cutDouble()
    {
        make_status();
        queue<int> qu;//存储根
        for(int i=0;i<n;++i)//根
        {
            if(status[i]==2)
            qu.push(i);
        }
        while(!qu.empty())
        {
            int root=qu.front();//cout<<root<<endl;
            qu.pop();
            vector<int> cache;
            cache.push_back(nums[root]);
            for(int x:edges[root])
            {
                if(mark[x])
                continue;
                if(lock[x]==1)
                {
                    --lock[x];
                    mark[x]=1;
                    cache.push_back(nums[x]);
                }
            }
            nums[root]=cal3(cache);
            lock[root]-=2;
            if(lock[root]==1)
            {
                for(int x:edges[root])
                {
                    if(mark[x])
                    continue;
                    ++status[x];
                    if(status[x]==2)
                    qu.push(x);
                }
            }
        }

    }

    int cal()
    {
        int mark_cnt=0;
        for(int x:mark)
        mark_cnt+=x;
        if(mark_cnt==n-1)
        {
            for(int i=0;i<n;++i)
            if(mark[i]==0)
            return nums[i];
        }
        int maxv=0;
        for(int i=0;i<n;++i)
        {
            if(mark[i])
            continue;
            if(status[i]==2)//一次操作中的根
            continue;
            if(lock[i]==1)
            continue;
            int target=-1;
            for(int x:edges[i])
            {
                if(mark[x])
                continue;
                if(lock[x]==1)
                {
                    target=x;
                    break;
                }
            }
            vector<int> temp;
            if(target!=-1)
            {
                for(int x:edges[i])
                {
                    if(mark[x])
                    continue;
                    if(lock[x]==1)
                    continue;
                    temp.push_back(nums[x]);
                }
                sort(temp.rbegin(),temp.rend());
                int rst=max(nums[i],min(nums[target],nums[0]));
                maxv=max(maxv,rst);
            }
            else
            {
                for(int x:edges[i])
                {
                    if(mark[x])
                    continue;
                    temp.push_back(nums[x]);
                }
                sort(temp.rbegin(),temp.rend());
                int rst=max(nums[i],min(nums[0],nums[1]));
                maxv=max(maxv,rst);
            }
        }
        //print(nums);
        return maxv;
    }

};
void Lonelyper(){
    int n,m;
    cin>>n>>m;
    vector<int> weight(n);
    for(auto&x:weight)
    cin>>x;
    vector<vector<int>> raw_edges(m,vector<int>(2));    
    for(auto&arr:raw_edges)
    {
    cin>>arr[0]>>arr[1];
    --arr[0];
    --arr[1];
    }
    meth *test=new meth(n,raw_edges,weight);
    test->cutDouble();
    int ans=test->cal();
    cout<<ans<<endl;
}

int main(){
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    int t = 1;
    //cin >> t;
    while(t --) Lonelyper();
    return 0;
}

详细

Test #1:

score: 100
Accepted
time: 0ms
memory: 3616kb

input:

7 9
1 4 1 3 3 6 7
5 4
3 6
3 4
2 3
5 2
2 6
6 7
5 1
4 6

output:

6

result:

ok single line: '6'

Test #2:

score: 0
Accepted
time: 0ms
memory: 3756kb

input:

5 7
1 5 3 1 4
3 5
1 3
5 1
1 4
5 4
2 4
3 2

output:

5

result:

ok single line: '5'

Test #3:

score: 0
Accepted
time: 0ms
memory: 3592kb

input:

7 7
2 4 2 3 3 6 7
5 1
2 6
5 3
4 6
1 6
1 2
2 7

output:

6

result:

ok single line: '6'

Test #4:

score: 0
Accepted
time: 0ms
memory: 3600kb

input:

3 2
2 2 2
2 3
1 3

output:

2

result:

ok single line: '2'

Test #5:

score: 0
Accepted
time: 0ms
memory: 3556kb

input:

5 5
3 1 2 4 5
3 2
2 4
3 5
5 1
2 5

output:

5

result:

ok single line: '5'

Test #6:

score: 0
Accepted
time: 0ms
memory: 3628kb

input:

7 9
3 2 3 5 2 6 7
7 4
5 4
5 6
1 7
1 6
2 3
7 6
6 4
4 2

output:

7

result:

ok single line: '7'

Test #7:

score: 0
Accepted
time: 0ms
memory: 3536kb

input:

3 2
1 2 3
3 1
2 1

output:

2

result:

ok single line: '2'

Test #8:

score: 0
Accepted
time: 0ms
memory: 3632kb

input:

9 9
6 1 1 1 3 7 1 8 9
9 8
6 7
2 7
5 6
7 9
5 1
7 3
1 6
1 4

output:

9

result:

ok single line: '9'

Test #9:

score: 0
Accepted
time: 0ms
memory: 3600kb

input:

9 10
7 7 4 2 2 6 6 8 9
9 6
4 6
1 2
4 3
5 6
7 5
6 8
7 4
1 7
1 9

output:

9

result:

ok single line: '9'

Test #10:

score: 0
Accepted
time: 0ms
memory: 3620kb

input:

5 6
3 2 1 1 2
3 5
2 4
3 1
2 3
4 1
1 5

output:

3

result:

ok single line: '3'

Test #11:

score: 0
Accepted
time: 0ms
memory: 3752kb

input:

7 7
4 4 5 1 1 6 7
2 1
1 7
5 4
2 4
1 3
5 6
7 4

output:

7

result:

ok single line: '7'

Test #12:

score: -100
Wrong Answer
time: 0ms
memory: 3488kb

input:

17 17
2 15 7 13 8 6 12 8 10 13 15 5 7 8 13 16 17
5 9
6 1
7 9
6 10
16 15
3 6
14 3
11 6
12 15
8 4
9 10
7 6
15 6
2 10
8 10
13 6
17 7

output:

13

result:

wrong answer 1st lines differ - expected: '16', found: '13'