首页 > 其他分享 >时间和空间复杂度

时间和空间复杂度

时间:2024-07-22 22:24:43浏览次数:20  
标签:arr int 复杂度 high 算法 时间 空间 public

目录

 一、时间复杂度

 1.1 定义

1.2 分类

二、空间复杂度

 2.1 定义

 2.2 分类

 2.3 重要性


  在计算机科学中,算法的效率是一个至关重要的概念。评估算法的效率通常涉及两个主要方面:时间复杂度和空间复杂度。这两个概念不仅帮助我们理解算法在处理数据时的表现,还为开发高效的程序提供了理论基础。本文将深入探讨时间复杂度和空间复杂度的定义、计算方法及其在实际应用中的重要性。

 一、时间复杂度

 1.1 定义

  时间复杂度是用来描述算法执行所需时间与输入规模之间关系的函数。换句话说,时间复杂度衡量的是算法在最坏情况下所需的时间。通常,时间复杂度用大O符号表示,例如O(n)、O(log n)等。

1.2 分类

时间复杂度可以分为几类,主要包括:

  常数时间复杂度 O(1)**:算法的执行时间不随输入规模的变化而变化。例如,访问数组中的某个元素。

  示例:
  
 

public class TimeComplexity {
      public static int getFirstElement(int[] arr) {
          return arr[0]; // O(1)
      }
  }


 

  对数时间复杂度 O(log n):算法的执行时间随着输入规模的增加而以对数的形式增长。典型的例子是二分查找算法。

  示例:

 

  public class TimeComplexity {
      public static int binarySearch(int[] arr, int target) {
          int left = 0, right = arr.length - 1;
          while (left <= right) {
              int mid = (left + right) / 2;
              if (arr[mid] == target) {
                  return mid; // 找到目标
              } else if (arr[mid] < target) {
                  left = mid + 1; // 在右侧查找
              } else {
                  right = mid - 1; // 在左侧查找
              }
          }
          return -1; // 未找到
      }
  }

  线性时间复杂度 O(n):算法的执行时间与输入规模成正比。例如,遍历一个数组。

  示例:
 

  public class TimeComplexity {
      public static void printElements(int[] arr) {
          for (int element : arr) {
              System.out.println(element); // O(n)
          }
      }
  }
 

  线性对数时间复杂度 O(n log n):这类复杂度通常出现在高效的排序算法中,如归并排序和快速排序。  示例(快速排序):
 

  public class TimeComplexity {
      public static void quickSort(int[] arr, int low, int high) {
          if (low < high) {
              int pi = partition(arr, low, high);
              quickSort(arr, low, pi - 1); // 递归左侧
              quickSort(arr, pi + 1, high); // 递归右侧
          }
      }

      private static int partition(int[] arr, int low, int high) {
          int pivot = arr[high];
          int i = (low - 1);
          for (int j = low; j < high; j++) {
              if (arr[j] < pivot) {
                  i++;
                  int temp = arr[i];
                  arr[i] = arr[j];
                  arr[j] = temp;
              }
          }
          int temp = arr[i + 1];
          arr[i + 1] = arr[high];
          arr[high] = temp;
          return i + 1;
      }
  }


 

平方时间复杂度 O(n^2):这类复杂度通常出现在嵌套循环中的操作,如冒泡排序。

  示例(冒泡排序):


  public class TimeComplexity {
      public static void bubbleSort(int[] arr) {
          int n = arr.length;
          for (int i = 0; i < n - 1; i++) {
              for (int j = 0; j < n - i - 1; j++) {
                  if (arr[j] > arr[j + 1]) {
                      // 交换 arr[j] 和 arr[j+1]
                      int temp = arr[j];
                      arr[j] = arr[j + 1];
                      arr[j + 1] = temp;
                  }
              }
          }
      }
  }


 

二、空间复杂度

 2.1 定义

  空间复杂度是用来描述算法在执行过程中所需空间(内存)与输入规模之间关系的函数。空间复杂度同样是利用大O符号表示。

 2.2 分类

空间复杂度通常包括以下几类:

  常数空间复杂度 O(1)**:算法所需的额外空间与输入规模无关。例如,交换两个变量时只需使用常量空间。

  示例:
 

  public class SpaceComplexity {
      public static void swap(int a, int b) {
          int temp = a;
          a = b;
          b = temp; // O(1)
      }
  }


 

  线性空间复杂度 O(n):算法的空间需求与输入规模成正比。例如,归并排序需要额外的数组来存放临时结果。

  示例(归并排序):
 

  public class SpaceComplexity {
      public static void merge(int[] arr, int left, int mid, int right) {
          int n1 = mid - left + 1;
          int n2 = right - mid;
          int[] L = new int[n1];
          int[] R = new int[n2];
          for (int i = 0; i < n1; ++i)
              L[i] = arr[left + i];
          for (int j = 0; j < n2; ++j)
              R[j] = arr[mid + 1 + j];
          // 合并过程
      }
  }


  

 2.3 重要性

  理解时间和空间复杂度对于开发高效的算法和程序至关重要。在很多情况下,优化算法的时间复杂度可以明显提高程序的运行速度,而优化空间复杂度则可以降低内存消耗。选择合适的算法不仅能提高程序的性能,还能提升用户体验,尤其是在处理大规模数据时。

标签:arr,int,复杂度,high,算法,时间,空间,public
From: https://blog.csdn.net/XHgga_/article/details/140621171

相关文章

  • 【Python datetime模块精讲】:时间旅行者的日志,精准操控日期与时间
    当然,让我们深入探讨Python的datetime模块,详细解释其功能和用法。Pythondatetime模块:时间旅行者的日志在编程中,日期和时间的处理是一个常见但复杂的问题。幸运的是,Python的datetime模块为我们提供了一套全面的解决方案。这个模块不仅包括日期和时间的基本表示,还提供......
  • 如何减少 Docker 日志大小,有效节省磁盘空间
    Docker是一个强大的容器化平台,它允许开发者在一个独立的环境中运行应用程序。虽然Docker提供了很多便利,但在实际使用过程中,日志文件可能会迅速增长,占用大量的磁盘空间。本文将详细介绍如何减少Docker日志大小,从而有效节省磁盘空间。Docker日志机制Docker使用日志......
  • 【动态规划】【官解+整洁度优化+状态压缩-空间优化算法】力扣198.打家劫舍
    你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。给定一个代表每个房屋存放金额的非负整数数组,计算你不触动警报装置的情况下,一夜......
  • sql server 事务日志释放空间
    您收到的错误消息表明数据库'EastRiver'的事务日志已满,导致数据库操作失败。要解决这个问题,可以按照以下步骤操作:1.备份事务日志首先,备份事务日志以释放空间:BACKUPLOG[EastRiver]TODISK=N'C:\Backup\EastRiver_log.bak'GO2.收缩事务日志文件备份日志后,可以使用DBCC......
  • 01-复杂度3 二分查找 陈越、何钦铭数据结构
    题目可以满分通过的答案:`PositionBinarySearch(ListL,ElementTypeX){Positionleft=1;Positionright=L->Last;while(left<=right){Positioncenter=(left+right)/2;if(L->Data[center]>X){right=center-1;}elseif(L->Data......
  • Linux工作原理6用户空间如何启动
    6用户空间如何启动内核启动init(第一个用户空间进程)的时刻意义重大--不仅仅是因为内存和CPU终于可以正常运行系统了,还因为在这个时刻,你可以看到系统的其他部分是如何作为一个整体建立起来的。在此之前,内核的执行路径都是由相对较少的软件开发人员定义好的。用户空间的模块化和......
  • 独立高防服务器特点免费全能空间存在吗
    独立高防服务器,是在独享整台服务器硬件资源和卓越性能的基础上独立高防服务器有哪些特点呢?因为独立高防服务器具有超强稳定性,用户可安装独立的操作系统,http、ftp、ssh、sendmail、mysql等都是独立的,只有你一个人在用,不像虚拟主机一样是免费服务器很多人共享,在安全性、性能、......
  • 时间序列分析方法汇总对比及优缺点和适用情况(下)-- 11. 卡尔曼滤波 12. 广义自回归条件
    目录11.卡尔曼滤波(KalmanFilter)12.广义自回归条件异方差模型(GARCH)13.贝叶斯结构时间序列模型(BayesianStructuralTimeSeries,BSTS)14.动态因子模型(DynamicFactorModel,DFM)15.隐马尔科夫模型(HiddenMarkovModel,HMM)16.分段线性回归(PiecewiseLinearRegress......
  • 基于声学基元的高质量空间音频生成框架
    关键词:人体姿态、声学基元、空间音频建模、体积渲染    过去几年中,渲染和动画制作逼真的3D人体模型技术已经发展成熟,并且达到了令人印象深刻的质量水平。然而,与这些全身模型相关联的空间音频建模,却在很大程度上被忽视了。换句话说,尽管我们已经能够创建视觉上令人信服......
  • 虚拟机(ubuntu22.04)空间不足,进行硬盘扩容
    1、编辑虚拟机设置(外部操作)关闭虚拟机编辑虚拟机设置---硬盘扩容虚拟机设置--->硬件--->改变磁盘大小--->点击<扩展>2、虚拟机内部磁盘重新分区(内部操作)开启虚拟机安装界面化的磁盘管理工具终端输入sudoaptinstallgparted终端输入sudogparted,打开该工具......