zoukankan      html  css  js  c++  java
  • 互相送礼物

    https://codeforces.com/contest/1283/problem/C

    题意:n个人相互送礼物,每个只能送一份礼物且接收一份礼物,不能自己送自己。

    给出n个数,0代表第i个人不知道送礼物给谁(最少有两个0)。要求给出完整的n人送礼物方案。

    解法:两个数组分别储存谁没收到礼物和谁不知道送礼物给谁。通过不能自己送自己这一条件,

    进行调整。

    //#include <bits/stdc++.h>
    #include <cstdio>
    #include <cstring>
    #include <cmath>
    #include <algorithm>
    #include <iostream>
    #include <cstdio>
    #include <string>
    #include <stdio.h>
    #include <queue>
    #include <stack>
    #include <map>
    #include <set>
    #include <string.h>
    #include <vector>
    #define ME(x , y) memset(x , y , sizeof(x))
    #define SF(n) scanf("%d" , &n)
    #define rep(i , n) for(int i = 0 ; i < n ; i ++)
    #define INF  0x3f3f3f3f
    #define mod 1000000007
    #define PI acos(-1)
    using namespace std;
    typedef long long ll ;
    int f[200009];//原数组谁给了谁。
    int vis[200009] ;//标记谁收到了礼物
    int a[200009] ;//存储谁没收到了礼物
    int g[200009];//存储谁不知道把礼物送给谁
    
    int main()
    {
        int n ;
        scanf("%d" , &n);
        int cnt = 0 ;
        for(int i = 1 ; i <= n ; i++)
        {
            scanf("%d" , &f[i]);
            if(f[i]) vis[f[i]] = 1;
            else g[cnt++] = i ;
        }
        cnt = 0 ;
        for(int i = 1 ; i <= n ; i++)
        {
            if(!vis[i]) a[cnt++] = i ;
        }
        for(int i = 0 ; i < cnt ; i++)
        {
            if(a[i] == g[i])
            {
                swap(a[i] , a[cnt-1]);
            }
        }
        if(a[cnt-1] == g[cnt-1]) swap(a[cnt-1] , a[0]);
        for(int i = 0 ; i < cnt ; i++)
        {
            f[g[i]] = a[i];
        }
        for(int i = 1 ; i < n ; i++)
        {
            cout << f[i] << " "  ;
        }
        cout << f[n] << endl ;
    
        return 0 ;
    }
    
  • 相关阅读:
    子库存安全性控制
    检查装配件属性
    检查加工费是否有父件
    检查委外货位
    只允许操作外协任务
    检查是否存在工艺路线
    不能取组织ID
    加宽任务号宽度
    采购订单供应商地点必输
    只显示标准采购订单
  • 原文地址:https://www.cnblogs.com/nonames/p/12238157.html
Copyright © 2011-2022 走看看