当前位置: 首页 > news >正文

比较正规的招聘网站wordpress 内部函数

比较正规的招聘网站,wordpress 内部函数,开发一款app软件需要多少钱,常熟网站开发题目 数对 (a,b) 由整数 a 和 b 组成&#xff0c;其数对距离定义为 a 和 b 的绝对差值。 给你一个整数数组 nums 和一个整数 k &#xff0c;数对由 nums[i] 和 nums[j] 组成且满足 0 < i < j < nums.length 。返回 所有数对距离中 第 k 小的数对距离。 示例 1&#x…

题目

数对 (a,b) 由整数 a 和 b 组成,其数对距离定义为 a 和 b 的绝对差值。
给你一个整数数组 nums 和一个整数 k ,数对由 nums[i] 和 nums[j] 组成且满足 0 <= i < j < nums.length 。返回 所有数对距离中 第 k 小的数对距离。
示例 1:
输入:nums = [1,3,1], k = 1
输出:0
解释:数对和对应的距离如下:
(1,3) -> 2
(1,1) -> 0
(3,1) -> 2
距离第 1 小的数对是 (1,1) ,距离为 0 。
示例 2:
输入:nums = [1,1,1], k = 2
输出:0
示例 3:
输入:nums = [1,6,1], k = 3
输出:5
参数范围
n == nums.length
2 <= n <= 104
0 <= nums[i] <= 106
1 <= k <= n * (n - 1) / 2

分析

排序不影响结果

数对的数量: n*(n-1)/2 ,任选两个数,共nn组数对,排除n个相等的索引,共n(n-1)。(a,b)和(b,a)只算一对。由于k取值范围[1,n*(n-1)/2],所以本题一定有解。
改成排序后,选取[i,j]和不排序的结果一样。 如果排序后,i和j的相对顺序不边,排序之前选取{i,j},排序选取的也是{i,j};如果排序后,相对顺序发生变化{i,j}变成{j,i}。数量不变。

二分

枚举差[0,1000*1000]。如果小于等于iSub的数对数量小于k,则一定不是答案。如果小于等于iSub的数对数量大于等于k,则取第一个(索引最小)。故用左开右闭空间。

GetLessEqual

nums[i] - x <=iSub
也就是 nums[i] - iSub<= x
也就是x >= nums[i] - iSub
枚举,并二分查找并计算nums[0,i)中大于等于 nums[i] - iSub的数量

代码

核心代码

class Solution {
public:
int smallestDistancePair(vector& nums, int k) {
sort(nums.begin(), nums.end());
int left = -1, right = 1000 * 1000;
while (right - left > 1)
{
const int mid = left + (right - left) / 2;
if (GetLessEqual(nums, mid) < k)
{
left = mid;
}
else
{
right = mid;
}
}
return right;
}
int GetLessEqual(const vector& nums, int iSub)
{
int iRet = 0;
for (int i = 1; i < nums.size(); i++)
{
const int iNum = nums.begin() + i - std::lower_bound(nums.begin(), nums.begin()+i, nums[i]-iSub );
iRet += iNum;
}
return iRet;
}
};

测试用例

template
void Assert(const T& t1, const T& t2)
{
assert(t1 == t2);
}

template
void Assert(const vector& v1, const vector& v2)
{
if (v1.size() != v2.size())
{
assert(false);
return;
}
for (int i = 0; i < v1.size(); i++)
{
Assert(v1[i], v2[i]);
}
}

int main()
{
vector nums;
int k = 0;
int res = 0;
{
Solution slu;
nums = { 1,3,1 };
int k = 1;
res = slu.smallestDistancePair(nums, k);
Assert(0, res);
}

//CConsole::Out(res);

}

扩展阅读

视频课程

有效学习:明确的目标 及时的反馈 拉伸区(难度合适),可以先学简单的课程,请移步CSDN学院,听白银讲师(也就是鄙人)的讲解。
https://edu.csdn.net/course/detail/38771

如何你想快速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程
https://edu.csdn.net/lecturer/6176

相关下载

想高屋建瓴的学习算法,请下载《闻缺陷则喜算法册》doc版
https://download.csdn.net/download/he_zhidan/88348653

鄙人想对大家说的话
闻缺陷则喜是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。
墨家名称的来源:有所得以墨记之。
如果程序是一条龙,那算法就是他的是睛

测试环境

操作系统:win7 开发环境: VS2019 C++17
或者 操作系统:win10 开发环境: VS2022 C++17

http://www.15wanjia.com/news/176861.html

相关文章:

  • 基础网站建设素材网站虚拟主机查询
  • 网站批量查询工具网站开发前端需要学什么
  • 做网站流量钱谁给毕设做网站些什么比较简单
  • 海淀网站建设wzjs51深圳网络建设网站
  • 分类信息网站系统cmsid怎么编辑wordpress
  • 上海政务网站建设网页微信聊天电脑有记录吗
  • 沈阳做网站优化丽水市莲都建设分局网站
  • wordpress安卓显示图片网站首页seo关键词布局
  • 湖北省建设厅网站上岗证查询手机网站大全网站
  • 网站 布局东阿做网站推广
  • WordPress如何获取logoseo百家外链网站
  • php网站如何做特效大学生个体创业的网站建设
  • 高端网站建设 杭州杭州网页设计培训课程
  • 学校网站建设好么深圳创业补贴政策2023申请流程
  • 家居装修企业网站源码wordpress视频播放器m3u8
  • wordpress全站固定链接公众号开放域名的443端口
  • asp网站中停止后面代码的运行wordpress购物模板下载
  • 网站如何做seo优化ps设计网页
  • 西安网站建设多少钱网站排名下降的原因
  • 网站群集约化建设通知嵌入式软件开发工具的发展趋势是什么
  • 如何推广网站网站推广常用方法如何制作小程序的详细步骤
  • 科协建设网站 方案西安做网站那家公司好
  • 如何检查网站死链三星网上商城app
  • 简单网站制作步骤用vs做网站教程
  • 公司网站用个人备案可以seo整站优化 wordpress
  • wordpress网站统计代码网站建设教程 湖南岚鸿
  • 江门公司网站制作临汾做网站的公司
  • 宜昌便宜做网站长春网站排名优化费用
  • 建设网站的内容html编辑器汉化版apk
  • 龙华建设局网站前端招聘网站