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

html网站发布客户管理软件哪个好用

html网站发布,客户管理软件哪个好用,做美图 网站有哪些,专做蓝领招聘网站有哪些问题描述: 给定一个下标从 0 开始的正整数数组 nums&#xff0c;我们的目标是找出并统计满足下述条件的三元组 (i, j, k) 的数目&#xff1a; 0 < i < j < k < nums.length&#xff0c;这确保了三元组索引的顺序性。nums[i]、nums[j] 和 nums[k] 两…

问题描述:             

给定一个下标从 0 开始的正整数数组 nums,我们的目标是找出并统计满足下述条件的三元组 (i, j, k) 的数目:

  1. 0 <= i < j < k < nums.length,这确保了三元组索引的顺序性。
  2. nums[i]nums[j] 和 nums[k] 两两不同,即 nums[i]!= nums[j]nums[i]!= nums[k] 且 nums[j]!= nums[k]

暴力解法 - 三层循环遍历

最直观的解法就是使用三层嵌套循环来遍历数组的所有可能组合

#include <stdio.h>// 函数定义,用于找出满足条件的三元组数量
int unequalTriplets(int* nums, int numsSize) {int count = 0;for (int i = 0; i < numsSize - 2; i++) {for (int j = i + 1; j < numsSize - 1; j++) {for (int k = j + 1; k < numsSize; k++) {if (nums[i]!= nums[j] && nums[i]!= nums[k] && nums[j]!= nums[k]) {count++;}}}}return count;
}int main() {int nums[] = {1, 2, 3, 4};  // 示例数组,你可以替换成其他测试数组int numsSize = sizeof(nums) / sizeof(nums[0]);int result = unequalTriplets(nums, numsSize);printf("满足条件的三元组数目为: %d\n", result);return 0;
}

在这段代码中:

  • 最外层循环控制第一个索引 i,它从数组起始位置开始,一直到倒数第 3 个位置(因为后面还需要留出 j 和 k 的位置)。
  • 中间层循环控制第二个索引 j,它从 i + 1 开始,确保 j > i,到倒数第 2 个位置。
  • 最内层循环控制第三个索引 k,从 j + 1 开始,保证 k > j,直到数组末尾。
  • 在内层循环里,每次都检查当前的三个元素是否两两不等,如果是,就将计数变量 count 加 1。最终,count 存储的就是满足条件的三元组数量。

这种解法简单直接,但时间复杂度高达 o(n^{3}),其中 n 是数组 nums 的长度。在大规模数据面前,性能会急剧下降。

优化解法 - 计数与组合数学原理

为了提升效率,我们可以换个思路。先统计数组中每个数字出现的频次,再利用组合数学的原理来计算满足条件的三元组数量。

#include <stdio.h>// 函数定义,用于找出满足条件的三元组数量
int unequalTriplets(int* nums, int numsSize) {int count = 0;// 用于记录每个数字出现的次数int num_count[1001] = {0};for (int i = 0; i < numsSize; i++) {num_count[nums[i]]++;}int left = 0;int right = numsSize;for (int i = 0; i < 1001; i++) {if (num_count[i] > 0) {right -= num_count[i];count += left * num_count[i] * right;left += num_count[i];}}return count;
}int main() {int nums[] = {1, 2, 3, 4};  // 示例数组,你可以替换成其他测试数组int numsSize = sizeof(nums) / sizeof(nums[0]);int result = unequalTriplets(nums, numsSize);printf("满足条件的三元组数目为: %d\n", result);return 0;
}
  • 首先,创建一个大小为 1001 的数组 num_count(假设数组中的数字最大不超过 1000,可根据实际情况调整),用于记录每个数字在 nums 数组里出现的频次。通过一次遍历 nums 数组,将每个数字对应的频次在 num_count 中累加。
  • 接着,使用两个变量 left 和 rightleft 初始化为 0,表示当前数字左边不同数字的个数;right 初始化为数组长度 numsSize,代表当前数字右边不同数字的个数。
  • 遍历 num_count 数组时,每当遇到一个数字出现次数不为 0:
    • 先更新 right,将其减去当前数字的出现次数,因为这些数字已经被算到当前位置左边或当前位置了,不能再算在右边。
    • 根据组合数学原理,当前数字与左边不同数字和右边不同数字能组成的满足条件三元组数量为 left * num_count[i] * right,累加到 count 中。
    • 最后更新 left,将当前数字的出现次数累加到 left 上,准备处理下一个数字。

这种优化后的解法时间复杂度降低到 ,其中 n 是数组 nums 的长度,m 是数组中不同数字的个数。相比暴力解法,大大提高了计算效率。

总结与拓展:

从简单直接但低效的暴力解法,到巧妙利用数据统计和数学原理的高效解法,效率得到了质的飞跃。在实际编程中,面对类似问题,我们应多思考数据的内在规律,尝试从不同角度去拆解问题,运用合适的数学知识或数据结构来优化算法。

希望通过这篇博客,大家对数组计数类算法问题有了更清晰的理解,也能在日后的编程实践中灵活运用这些思路去攻克难题。

 

http://www.ds6.com.cn/news/30723.html

相关文章:

  • 网站开发目的和意义百度指数app官方下载
  • 应该怎样做网站地图12345浏览器
  • 专门做外贸网站微信crm客户管理系统
  • 怎么样在网站文章最后做超链接百度品牌广告
  • 微信3g网站开发app推广方法及技巧
  • 推荐佛山顺德网站建设如何制作一个简单的网页
  • 买房网站排名网站快速排名案例
  • 石家庄做网站的口碑好班级优化大师功能介绍
  • 陕西的建设厅官方网站直通车关键词优化口诀
  • 做简单网站代码如何优化网页
  • 重庆奉节网站建设html网页制作成品
  • 企业内部系统网站制作友链对网站seo有帮助吗
  • 上海大型网站建设公司排名宁波seo关键词优化方法
  • 香港gmt做空网站长沙优化科技有限公司正规吗
  • 泉州网站建设工作室sem分析是什么
  • 运城建设厅官方网站活动软文模板
  • 宁夏做网站百度关键词优化多少钱
  • 福建平潭建设局网站业务推广公司
  • 网站页脚写什么人工智能培训心得
  • 跨国购物网站建设费用搜狗搜索旧版本
  • 爱藏网一家专业做收藏品的网站百度seo推广方案
  • 广州企业年报网上申报入口seo快速工具
  • 乌兰察布做网站的公司长尾关键词挖掘精灵
  • 潮州哪里做网站搜索最全的搜索引擎
  • 个人可以做建站网站么东莞网站制作公司
  • 南通专业网站建设公司百度搜索引擎服务项目
  • 网站关键词设置多少合适网络服务合同纠纷
  • 专业网站建设公司网站优化排名优化
  • 巨野有做网站的公司吗西地那非片的功能主治
  • 房天下二手房官网学校seo推广培训班