C++实现简单排序算法及.h文件应用

版权申诉
0 下载量 181 浏览量 更新于2024-10-13 收藏 6KB ZIP 举报
资源摘要信息:"本项目名为Progect1_排序_PROGECT1_,主要关注了几种基础的排序算法,并使用C++语言进行了实现。这些排序算法的功能被编写在了头文件(.h文件)中,以方便模块化管理和调用。排序算法是计算机科学中不可或缺的基础知识,它们广泛应用于数据处理和软件开发领域,用于将一系列元素按照特定的顺序重新排列。常见的排序算法包括冒泡排序、选择排序、插入排序、快速排序、归并排序等。" 知识点一:冒泡排序(Bubble Sort) 冒泡排序是一种简单直观的排序算法。它重复地遍历要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小(或越大)的元素会经由交换慢慢“浮”到数列的顶端。 知识点二:选择排序(Selection Sort) 选择排序算法是一种原址比较排序算法。选择排序大致的思路是遍历待排序的数组,找到数据结构中的最小(或最大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(或最大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。 知识点三:插入排序(Insertion Sort) 插入排序的工作方式像很多人玩扑克牌时整理手中的牌。算法从第一个元素开始,该元素可以认为已经被排序;取出下一个元素,在已经排序的元素序列中从后向前扫描;如果该元素(已排序)大于新元素,将该元素移到下一位置;重复步骤3,直到找到已排序的元素小于或者等于新元素的位置;将新元素插入到该位置后;重复步骤2~5。 知识点四:快速排序(Quick Sort) 快速排序是由东尼·霍尔所发展的一种排序算法。在平均状况下,排序一个n元素的时间复杂度为O(nlogn)。快速排序使用分治法策略来把一个序列分为较小和较大的两个子序列,然后递归地排序两个子序列。其核心思想是“分而治之”,通过一个划分操作将数据分为独立的两部分,其中一部分的所有数据都比另一部分的所有数据要小,然后再递归地对这两部分数据分别进行快速排序,以达到整个序列有序。 知识点五:归并排序(Merge Sort) 归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。归并操作指的是将两个已经排序的序列合并成一个序列的操作。首先将待排序的数组分成若干个子数组,每个子数组是有序的,然后将有序的子数组合并,最终得到一个完全有序的数组。 知识点六:C++编程语言 C++是一种支持多范式编程的静态类型、编译式、通用编程语言。它支持过程化编程、面向对象编程和泛型编程。C++被广泛用于系统软件、游戏开发、嵌入式系统、高性能服务器和客户端开发等领域。在本项目中,使用C++来实现排序算法,展示了面向对象的封装性以及函数的模块化设计。 通过以上知识点的解释,可以了解到本项目所涉及的几种排序算法的特点和适用情况。了解这些基本算法对于深入理解更复杂的排序算法和数据结构具有重要作用。同时,将排序函数写在头文件中,使得这些函数具有更好的复用性和模块性。这对于编写结构化和易于维护的代码是非常有帮助的。

改为pgsql select c.* from ( select a.* from ( SELECT t.PROJ_ID,t.PROJ_CODE,t.PROJ_NAME,t.CLIENT_CODE,t.CLIENT_NAME,t.SPEC_CODE,t.SPEC_NAME,t.BUS_UNIT_CODE,t.BUS_UNIT,t.PROJ_DEP_CODE,t.PROJ_DEP,t.PROJECT_MANAGER_CODE,t.PROJECT_MANAGER,t.PROJECT_DEP_MANAGER_CODE,t.PROJECT_DEP_MANAGER,t.IS_SUB_PROJ,t.SUB_PROJ_TYPE_CODE,t.SUB_PROJ_TYPE,t.PARENT_CODE,t.PROJ_GROSS,t.CLIENT_AREA_CODE,t.CLIENT_AREA,t.CLIENT_TYPE_FULL_PATH_CODE,t.CLIENT_TYPE_PULL_PATH,t.BUSINESS_TYPE_CODE,t.BUSINESS_TYPE,t.BUSINESS_LEVEL_CODE,t.BUSINESS_LEVEL,t.BUSINESS_AREA_CODE,t.BUSINESS_AREA_NAME,t.IS_CLOSE,t.IS_IN_COO,t.TAX_RATE,t.IS_AUTHORIZED,t.AUTHORIZED_AMOUNT,t.IS_VIRTUAL,t.INCOME_BUDGET,t.EXPENDITURE_BUDGET,t.P_VALUE,t.CREATE_TIME,t.P_BUD_VALUE,t.P1_BUD_VALUE,t.P2_BUD_VALUE,t.ORG_CODE,t.ORG_NAME,t.PROD_RES_TYPE,t.IS_TECH_COO,t.COO_UNIT_RATIO,t.PROJ_ACHIEVEMENTS_BUD,t.REIMBURSEMENT_COST_BUD,t.COO_COST_BUD,t.MATERIAL_COST_BUD,t.PERFORMANCE_PERCENT,t.SCHE_START_TIME,t.SCHE_END_TIME,t.PROJECT_ACCOUNT_CODE,t.CUSTOMER_TYPE_CODE,t.CUSTOMER_TYPE,t.IS_PURE_OUT_PROJ,t.PROJECT_CREATE_TIME,t.IS_RELATE,t.IS_QUOTA,t.MAIN_PROJECT_CODE,t.PROJ_STATUS,t.IS_LARGE_PROJECT,t.MARKET_DIS_COUNT_RATE,t.PROJECT_CAT,t.MGR_PER_FORMANCE_RATIO,t.P1_VALUE,t.S_VALUE,t.COOP_VALUE,t.H_VALUE,t.DEVICE_BUDGET_COST,t.SUR_FEE_DIS_COUNT_RATE,t.DES_FEE_DIS_COUNT_RATE, (select listagg(p.coo_unit_code, ',') within group(order by p.coo_unit_code) from ( select distinct coo_unit_code from t_spdi_proj where is_sub_proj = 'Y' and sub_proj_type_code = 'wbhz' and PROJ_STATUS != 'P_5' AND PROJ_STATUS != 'P_4' and parent_code = t.proj_code )p ) coo_unit_code, (select listagg(to_char(p.coo_unit), ',') within group(order by p.coo_unit) from ( select distinct coo_unit from t_spdi_proj where is_sub_proj = 'Y' and sub_proj_type_code = 'wbhz' and PROJ_STATUS != 'P_5' AND PROJ_STATUS != 'P_4' and parent_code = t.proj_code )p ) coo_unit from T_SPDI_PROJ t where -- and t.PARENT_CODE=#{parentCode:VARCHAR} t.IS_SUB_PROJ='Y' and t.SUB_PROJ_TYPE_CODE='zz' and t.PROJ_STATUS NOT IN ('E','H','W') order by t.proj_id )a )c

134 浏览量