整型数组处理算法(一)按照正态分布来排列整型数组元素

2024-06-16 08:18

本文主要是介绍整型数组处理算法(一)按照正态分布来排列整型数组元素,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目要求如下:

给定一个数组input[],

如果数组长度n为奇数,则将数组中最大的元素放到output[]数组最中间的位置,
如果数组长度n为偶数,则将数组中最大的元素放到 output[] 数组中间两个位置偏右的那个位置上,
然后再按从大到小的顺序,依次在第一个位置的两边,按照一左一右的顺序,依次存放剩下的数。


这种处理后结果,如果按照元素的值表示一种分布的图形的话,那绘制后的图形应该是正态分布。


关于正态分布:

正态分布(Normal distribution)又名高斯分布(Gaussian distribution),是一个在数学、物理及工程等领域都非常重要的概率分布,在统计学的许多方面有着重大的影响力。若随机变量X服从一个数学期望为μ、方差为σ^2的高斯分布,记为N(μ,σ^2)。其概率密度函数为正态分布的期望值μ决定了其位置,其标准差σ决定了分布的幅度。因其曲线呈钟形,因此人们又经常称之为钟形曲线。我们通常所说的标准正态分布是μ = 0,σ = 1的正态分布。




这里只是从结果上产生联系,算法与正态分布无关。


代码实现如下:

void sort(int input[],int output[], int n)
{int m=n;//cout<<m<<endl;int i,j,temp;bool exchange;//交换标志for(i=0;i<m-1;i++){ //最多做n-1趟排序exchange=FALSE; //本趟排序开始前,交换标志应为假for(j=m-2;j>=i;j--) //对当前无序区R[i..n]自下向上扫描if(input[j+1]<input[j]){//交换记录temp=input[j+1]; //R[0]不是哨兵,仅做暂存单元input[j+1]=input[j];input[j]=temp;exchange=TRUE; //发生了交换,故将交换标志置为真}if(!exchange) //本趟排序未发生交换,提前终止算法break;//cout<<input[5]<<endl;} for(int wc1=0; wc1<m; wc1++)//只是来显示排序结果~{cout<<input[wc1]<<" ";}cout << endl;int q=m-1;if((m%2)==0){int mid=m/2;for (int tempmid=0; tempmid<=mid; tempmid++)//注意循环语句的执行顺序{output[mid+tempmid]=input[q];q--;output[mid-tempmid-1]=input[q];q--;}}if((m%2)!=0)//注意循环语句的执行顺序{int mid=q/2;output[mid]=input[q];for (int tempmid=1;tempmid<=mid;tempmid++){q--;output[mid-tempmid]=input[q];q--;output[mid+tempmid]=input[q];}}for(int wc=0; wc<m; wc++){cout<<output[wc]<<" ";}cout << endl;
}


int main()
{int input[] = {3, 6, 1, 9, 7, 8, 2};int wc=0;int nCount = sizeof(input)/sizeof(int);for(wc=0; wc<nCount; wc++)//{cout<<input[wc] << " ";//cout<<"\n"<<endl;}cout << endl;int output[]= {3, 6, 1, 9, 7, 8, 2};sort(input,output, nCount);return 0;
}

测试结果:

当int input[] = {3, 6, 1, 9,7, 8, 2, 10};,结果如下:

3 6 1 9 7 8 2 10
1 2 3 6 7 8 9 10
1 3 7 9 10 8 6 2

当int input[] = {3, 6, 1, 9,7, 8, 2, 10};,结果如下:

3 6 1 9 7 8 2
1 2 3 6 7 8 9
2 6 8 9 7 3 


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






这篇关于整型数组处理算法(一)按照正态分布来排列整型数组元素的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

python3如何找到字典的下标index、获取list中指定元素的位置索引

《python3如何找到字典的下标index、获取list中指定元素的位置索引》:本文主要介绍python3如何找到字典的下标index、获取list中指定元素的位置索引问题,具有很好的参考价值,... 目录enumerate()找到字典的下标 index获取list中指定元素的位置索引总结enumerat

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

电脑提示xlstat4.dll丢失怎么修复? xlstat4.dll文件丢失处理办法

《电脑提示xlstat4.dll丢失怎么修复?xlstat4.dll文件丢失处理办法》长时间使用电脑,大家多少都会遇到类似dll文件丢失的情况,不过,解决这一问题其实并不复杂,下面我们就来看看xls... 在Windows操作系统中,xlstat4.dll是一个重要的动态链接库文件,通常用于支持各种应用程序

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是