整型数组处理算法(十三)请实现一个函数:凑14。[风林火山]

2024-06-16 08:08

本文主要是介绍整型数组处理算法(十三)请实现一个函数:凑14。[风林火山],希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

请实现一个函数:凑14;
输入很多个整数(1<=数值<=13),任意两个数相加等于14就可以从数组中删除这两个数, 
求剩余数(按由小到大排列);比如:输入数组[9,1,9,7,5,13], 输出数组[7,9] 。

实现代码如下:

int* MakeAndDelete(const int *InputArray, int count, int& OutPutCount, int MakeValue)
{int* Temp = new int[MakeValue];//保存1~13出现的次数int nOutCount = 0;//剩余元素个数int i;int j;int k;memset(Temp, 0, MakeValue*sizeof(int));//判断输入数字有效性,同时统计1~13出现的次数for (i=0; i<count; i++){if (InputArray[i]>=MakeValue || InputArray[i]<1){OutPutCount = -1;return NULL;//输入的数字不在1~13范围里}Temp[InputArray[i]]++;}//对个数进行计算:剩余个数或为0,或为差值,同时统计剩余元素个数for (i = 1; i < MakeValue / 2; i++) {  if (Temp[i] > Temp[MakeValue - i]) {  Temp[i] -= Temp[MakeValue - i];  Temp[MakeValue - i] = 0;nOutCount += Temp[i];} else {Temp[MakeValue - i] -= Temp[i];Temp[i] = 0;  nOutCount += Temp[MakeValue - i];}  }//如果是偶数,对2取余。if (MakeValue % 2 == 0) {  Temp[MakeValue / 2] = Temp[MakeValue / 2] % 2;  nOutCount += Temp[MakeValue / 2];}//剩余数不为0if (nOutCount > 0){k =0;OutPutCount = nOutCount;int* OutPutArray = new int[nOutCount];for (i= 1; i<MakeValue; i++){if (Temp[i]>0){for (j=0; j<Temp[i]; j++){OutPutArray[k++] = i;}}}return OutPutArray;}OutPutCount = 0;return NULL;}

有兴趣的朋友可以试试,仅提供参考。


转载请注明原创链接:http://blog.csdn.net/wujunokay/article/details/12586389



这篇关于整型数组处理算法(十三)请实现一个函数:凑14。[风林火山]的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1065908

相关文章

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

golang版本升级如何实现

《golang版本升级如何实现》:本文主要介绍golang版本升级如何实现问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录golanwww.chinasem.cng版本升级linux上golang版本升级删除golang旧版本安装golang最新版本总结gola

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 定时新增分区的实现示例

《MySQL定时新增分区的实现示例》本文主要介绍了通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,具有一定的参考价值,感兴趣的可以了解一下... mysql创建好分区之后,有时候会需要自动创建分区。比如,一些表数据量非常大,有些数据是热点数据,按照日期分区MululbU

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

MySQL中查找重复值的实现

《MySQL中查找重复值的实现》查找重复值是一项常见需求,比如在数据清理、数据分析、数据质量检查等场景下,我们常常需要找出表中某列或多列的重复值,具有一定的参考价值,感兴趣的可以了解一下... 目录技术背景实现步骤方法一:使用GROUP BY和HAVING子句方法二:仅返回重复值方法三:返回完整记录方法四:

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客