947. Most Stones Removed with Same Row or Column(Leetcode每日一题-2021.01.15)

给定一个二维平面上的石子分布,每行每列最多有一颗石子,可以移除与另一颗未移除石子在同一行或同一列的石子。求能移除的最大石子数。例如,对于输入[[0,0],[0,1],[1,0],[1,2],[2,1],[2,2]],最大可移除5颗石子。解决方案中使用了并查集数据结构来高效地查找和合并元素所属的集合,从而确定可以移除的石子对。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Problem

On a 2D plane, we place n stones at some integer coordinate points. Each coordinate point may have at most one stone.

A stone can be removed if it shares either the same row or the same column as another stone that has not been removed.

Given an array stones of length n where stones[i] = [xi, yi] represents the location of the ith stone, return the largest possible number of stones that can be removed.

Constraints:

  • 1 <= stones.length <= 1000
  • 0 <= xi, yi <= 104
  • No two stones are at the same coordinate point.

Example1

Input: stones = [[0,0],[0,1],[1,0],[1,2],[2,1],[2,2]]
Output: 5
Explanation: One way to remove 5 stones is as follows:
1.Remove stone [2,2] because it shares the same row as [2,1].
2.Remove stone [2,1] because it shares the same column as [0,1].
3.Remove stone [1,2] because it shares the same row as [1,0].
4.Remove stone [1,0] because it shares the same column as [0,0].
5.Remove stone [0,1] because it shares the same row as [0,0].
Stone [0,0] cannot be removed since it does not share a row/column with another stone still on the plane.

Example2

Input: stones = [[0,0],[0,2],[1,1],[2,0],[2,2]]
Output: 3
Explanation: One way to make 3 moves is as follows:
1.Remove stone [2,2] because it shares the same row as [2,0].
2.Remove stone [2,0] because it shares the same column as [0,0].
3.Remove stone [0,2] because it shares the same row as [0,0].
Stones [0,0] and [1,1] cannot be removed since they do not share a row/column with another stone still on the plane.

Example3

Input: stones = [[0,0]]
Output: 0
Explanation: [0,0] is the only stone on the plane, so you cannot remove it.

Solution

class Solution {
public:
    vector<int> p;

    int find(int x) {
        if (p[x] != x) p[x] = find(p[x]);
        return p[x];
    }

    int removeStones(vector<vector<int>>& stones) {

        int ret = 0;
        for(int i = 0;i<stones.size();++i)
            p.push_back(i);
        for(int i = 0;i<stones.size();++i)
            for(int j = i+1;j<stones.size();++j)
            {
                if(find(i) != find(j) && (stones[i][0] == stones[j][0] || stones[i][1] == stones[j][1]))
                {
                    p[find(i)] = find(j);
                    ++ret;
                }
            }

        return ret;

    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值