2023-08-23力扣每日一题

链接:

1782. 统计点对的数目

题意:

给n个点和m条无向边(可重复),q个查询

定义edge[a]为一个点是a的边数量,定义ret[a,b]edge[a]+edge[b]-(a与b的边)

q个查询q个答案,第i次查询值val[i],求所有的1<=a<b<=n条件下有多少ret[a,b]>val[i]

解:

TLE卡47了

看了评论区用空间换时间,双指针

实际代码:

c++ 复制代码
class Solution {
public:
    typedef pair<int,int> pii;
vector<int> countPairs(int n, vector<vector<int>>& edges, vector<int>& queries)
{
	vector<int>edgeNum(n+1);//记录edge[a]
	map<pii,int>edgePair;
	for(auto edge:edges)
	{
		if(edge[0]>edge[1]) swap(edge[0],edge[1]);
		edgeNum[edge[0]]++;
		edgeNum[edge[1]]++;
		edgePair[{edge[0],edge[1]}]++;//记录(a与b的边)
	}
	vector<int>ans;	
	vector<int>edgeNS(edgeNum);	
	sort(edgeNS.begin(),edgeNS.end());//空间换时间 排序
	
	for(auto querie:queries)
	{
		int temp=0;
		int left=1,right=n;
		while(left<right)//双指针 
		{
			if(edgeNS[left] + edgeNS[right] <= querie) left++;
			else
			{
				temp+= right-left;
				right--;
			}
		}
		for(auto Pair:edgePair)
		{
			int s=edgeNum[Pair.first.first]+edgeNum[Pair.first.second];
			if(s>querie && s-Pair.second<=querie) temp--;
		}
		ans.push_back(temp);
	}
	return ans;
}
};

限制:

  • 2 <= n <= 2 * 104
  • 1 <= edges.length <= 105
  • 1 <= ui, vi <= n
  • ui != vi
  • 1 <= queries.length <= 20
  • 0 <= queries[j] < edges.length
相关推荐
MZ_ZXD00123 分钟前
springboot旅游信息管理系统-计算机毕业设计源码21675
java·c++·vue.js·spring boot·python·django·php
TracyCoder1231 小时前
LeetCode Hot100(34/100)——98. 验证二叉搜索树
算法·leetcode
A星空1231 小时前
一、Linux嵌入式的I2C驱动开发
linux·c++·驱动开发·i2c
凡人叶枫2 小时前
C++中智能指针详解(Linux实战版)| 彻底解决内存泄漏,新手也能吃透
java·linux·c语言·开发语言·c++·嵌入式开发
会叫的恐龙2 小时前
C++ 核心知识点汇总(第六日)(字符串)
c++·算法·字符串
小糯米6012 小时前
C++顺序表和vector
开发语言·c++·算法
独望漫天星辰2 小时前
C++ 多态深度解析:从语法规则到底层实现(附实战验证代码)
开发语言·c++
We་ct2 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
王老师青少年编程3 小时前
2024年信奥赛C++提高组csp-s初赛真题及答案解析(阅读程序第3题)
c++·题解·真题·csp·信奥赛·csp-s·提高组
凡人叶枫3 小时前
C++中输入、输出和文件操作详解(Linux实战版)| 从基础到项目落地,避坑指南
linux·服务器·c语言·开发语言·c++