用于打印排序数组中形成 AP 的所有三元组的 JavaScript 程序

AP 是等差数列,其中两个连续元素之间的差始终相同。我们将使用三种方法打印形成 AP 的排序数组中的所有三元组:朴素方法、二分搜索方法和两指针方法。

问题简介

在这个问题中,我们得到一个排序数组,这意味着所有元素都是递增的形式。我们必须找到数组中的三个元素并形成一个 AP。例如 –

给定数组:1 5 2 4 3

从给定的数组中,我们有两个三元组:1 2 3 和 5 4 3,因为相邻元素之间的差异相等。另外,正如所写,我们只需找到三元组,这样我们就不会找到任何更长的序列。

让我们转向寻找三元组的方法 –

方法

天真的方法

在这种方法中,我们只是使用循环在数组上移动,并且对于每次迭代,我们将为与当前索引相比更大的数字运行另一个数组。然后我们将在第一个嵌套数组中再次实现一个嵌套数组,以查找可以形成AP的元素。让我们看看代码 –

示例

// function to find all the triplets 
function findAP(arr){
   var n = arr.length
   // traversing over the array
   for(var i = 0; i< n;i++){
      for(var j = i+1;j<n;j++){
         for(var k = j+1; k < n; k++){
            if(arr[j] - arr[i] == arr[k] - arr[j]) {
               console.log("Triplet is: " + arr[i] + " " + arr[j] + " " + arr[k]);
            }
         }
      }
   }
}
// defining the array and calling the function 
arr = [1, 5, 2, 4, 3]
findAP(arr)

上述代码的时间复杂度为O(),其中N是数组的大小。

上述代码的空间复杂度为 O(1),因为我们没有使用任何额外的空间。

遵循朴素方法

在前面的方法中,当我们有两个元素时,我们可以找到第三个元素,因为我们有共同的差异,所以要找到第三个元素,而不是使用线性搜索,我们可以使用二分搜索并降低时间复杂度上面的代码 –

示例

// function for binary search 
var binarySearch = function (arr, x, start, end) {
   if (start > end) return false;
   var mid=Math.floor((start + end)/2);
   if (arr[mid]===x) return true;
   if(arr[mid] > x)
      return binarySearch(arr, x, start, mid-1);
   else
      return binarySearch(arr, x, mid+1, end);
}
// function to find all the tripletes 
function findAP(arr){
   var n = arr.length
   // traversing over the array
   for(var i = 0; i< n;i++){
      for(var j = i+1;j<n;j++){
         // third element will be
         var third = 2*arr[j]-arr[i];
         if(binarySearch(arr,third,j+1,n)){
            console.log("Triplet is: " + arr[i] + " " + arr[j] + " " + third);
         }
      }
   }
}
// defining the array and calling the function 
arr = [1, 5, 2, 4, 3]
findAP(arr)

上述代码的时间复杂度为O(),其中N是数组的大小。

上述代码的空间复杂度为 O(1),因为我们没有使用任何额外的空间。

高效的方法

在这种方法中,我们将使用两个指针并查找与当前位置具有相同差异的元素。让我们看看代码 –

示例

// function to find all the triplets 
function findAP(arr){
   var n = arr.length
   
   // traversing over the array
   for(var i = 1; i< n;i++)    {
      var bptr = i-1
      var fptr = i+1
      while(bptr >= 0 && fptr < n)        {
         if(arr[i] - arr[bptr] == arr[fptr] - arr[i]){
            console.log("Triplet is: " + arr[bptr] + " " + arr[i] + " " + arr[fptr]);
            bptr--;
            fptr++;
         }
         else if(arr[i] - arr[bptr] > arr[fptr] - arr[i]){
            fptr++;
         }
         else{
            bptr--;
         }
      }
   }
}

// defining the array and calling the function 
arr = [1, 4, 7, 10, 13, 16]
findAP(arr)

上述代码的时间复杂度为 O(N*N),其中 N 是给定数组的大小,上述方法的空间复杂度为 O(1),因为我们没有使用任何额外的空间。 p>

注意 – 前两种方法对于任何类型的已排序或未排序的数组都是有效的,但最后一种方法仅适用于已排序的数组,如果数组未排序,我们可以对其进行排序一种方法,但这种方法仍然是所有其他方法中最好的。

结论

在本教程中,我们实现了一个 JavaScript 程序来打印给定排序数组中形成 AP 的所有三元组。 Ap 是算术级数,其中两个连续元素之间的差始终相同。我们已经看到了三种方法:时间复杂度为 O(N*N*N) 的朴素方法、时间复杂度为 O(N*N*log(N)) 的二分查找方法以及双指针方法。

以上就是用于打印排序数组中形成 AP 的所有三元组的 JavaScript 程序的详细内容,更多请关注双恒网络其它相关文章!

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
8. 精力有限,不少源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别
9.本站默认解压密码为:www.sudo1.com
本站提供的一切软件、教程和内容信息仅限用于学习和研究目的。
不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。
本站信息来自网络收集整理,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑或手机中彻底删除上述内容。
如果您喜欢该程序和内容,请支持正版,购买注册,得到更好的正版服务。
我们非常重视版权问题,如有侵权请邮件与我们联系处理。敬请谅解!

云资源网 » 用于打印排序数组中形成 AP 的所有三元组的 JavaScript 程序

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
提示下载完但解压或打开不了?
最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。 若排除这种情况,可在对应资源底部留言,或 联络我们.。
你们有qq群吗怎么加入?
当然有的,如果你是帝国cms、易优cms、和pbootcms系统的爱好者你可以加入我们的QQ千人交流群https://www.sudo1.com/page-qun.html。
  • 会员数(个)
  • 12310资源数(个)
  •        
  • 资源(G)
  •        
  • 今日下载
  • 1505稳定运行(天)

提供最优质的资源集合

立即查看 了解详情