社区讨论

有没有大佬帮我查查错(悬赏一关)

P1878舞蹈课参与者 2已保存回复 4

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
4 条
当前快照
1 份
快照标识符
@lo161elw
此快照首次捕获于
2023/10/22 15:47
2 年前
此快照最后确认于
2023/11/02 15:22
2 年前
查看原帖
有没有大佬帮我查查错
C
#include<bits/stdc++.h>
using namespace std;
int n;
int a[200005];
int vis[200005];
int sum=0;
int ans1[200005];
int ans2[200005];
string s;
struct node
{
    int qian;
    int hou;
    int cha;
};
struct jiedian
{
    int before;
    int next;
}lianbiao[200005];
priority_queue<node> q;
bool operator<(node a,node b)
{
	if(a.cha==b.cha)
        	return a.qian>b.qian;
	else return a.cha>b.cha;
}
void qpush(int a,int b,int c)
{
    node d;
    d.qian=a;
    d.hou=b;
    d.cha=c;
    q.push(d);
}
int main()
{
    cin>>n>>s;
    s+='H';
    for(int i=1;i<=n;i++)
    	cin>>a[i];
    for(int i=1;i<=n;i++)
    {
        lianbiao[i].before=i-1;
        lianbiao[i].next=i+1;
    }
    for(int i=1;i<n;i++)
        if(s[i-1]!=s[i])
            qpush(i,i+1,abs(a[i]-a[i+1]));
    while(!q.empty())
    {
        node now=q.top();
        q.pop();
        if(vis[now.qian]==false&&vis[now.hou]==false)
        {
            lianbiao[lianbiao[now.qian].before].next=lianbiao[now.hou].next;
            lianbiao[lianbiao[now.hou].next].before=lianbiao[now.qian].before;
            sum++;
            ans1[sum]=now.qian;
            ans2[sum]=now.hou;
            vis[now.qian]=true;
            vis[now.hou]=true;
            if(now.qian!=1&&now.hou!=n&&vis[lianbiao[now.qian].before]==false&&vis[lianbiao[now.hou].next]==false&&s[lianbiao[now.qian].before-1]!=s[lianbiao[now.hou].next-1])
                qpush(lianbiao[now.qian].before,lianbiao[now.hou].next,abs(a[lianbiao[now.qian].before]-a[lianbiao[now.hou].next]));
        }
    }
    cout<<sum<<endl;
    for(int i=1;i<=sum;i++)
        cout<<ans1[i]<<" "<<ans2[i]<<endl;
    return 0;
}

回复

4 条回复,欢迎继续交流。

正在加载回复...