使用给定的操作将数组缩减为一个元素
给定一个整型变量 Number 作为输入。让我们考虑一个按排序顺序包含 1 到 Number 范围内的元素的数组。如果我们对数组执行操作,则每一步都会删除奇数位置的元素。那么目标就是执行这个操作N 直到只剩下一个元素为止的次数。在末尾打印该元素。
注意 -:元素的定位使得索引 0 处的数组位于第 1 个位置,依此类推。
元素数量的测试用例在数组中
输入数字=1,输出= 1
输入数字=2,输出= 2
输入数字=3,输出= 2
>输入数量=4,输出=4
输入数量=5,输出=4
输入数量=6,输出=4
输入数量=7,输出= 4
......
输入数量=12,输出= 8
输入数量=20,输出= 16
根据上述观察,对于 2i 到 2i+1-1 之间的数字范围,输出将为 2i .
示例
输入 −Number=7
输出 − 单个归约操作后的元素为:4
解释− 第一个元素位于位置 1,依此类推。
数组将为 [ 1 2 3 4 5 6 7 ]
第一次操作后:[ 2 4 6 ]
第二次操作后:[ 4 ]
输入 − 数字=18
输出− 归约运算后的单个元素为:4
解释 − 第一个元素位于位置 1 且
数组将是 [ 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 ]
第一次操作后: [ 2 4 6 8 10 12 14 16 18]
第 2 次操作后:[ 2 8 12 16 ]
第 3 次操作后:[ 8 16 ]
第 4 次操作后 [ 16 ]
下面程序中使用的方法如下
在这种方法中,我们将使用 while 循环根据上面的公式计算最终结果。以初始值为2,遍历直到2*结果
-
取输入变量Number
函数 getsingleElement(long num) 获取输入数字并根据上述公式打印结果。
获取变量结果。
用2初始化结果。
使用while循环遍历,直到结果*2 li>
will 内的双倍结果。
一旦 while 循环结束,我们就会得到所需的值。
在main中打印结果。
返回结果。
示例
#include<bits/stdc++.h> using namespace std; long getsingleElement(long num){ long result; result=2; while(result*2 <= num){ result=result*2; } return result; } int main(){ int Number = 20; cout<<"The single element after reduction operation is : "<<getsingleElement(Number) ; return 0; }
输出
如果我们运行上面的代码,它将生成以下输出
The single element after reduction operation is : 16
以上是使用给定的操作将数组缩减为一个元素的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

使用foreach循环去除PHP数组中重复元素的方法如下:遍历数组,若元素已存在且当前位置不是第一个出现的位置,则删除它。举例而言,若数据库查询结果存在重复记录,可使用此方法去除,得到不含重复记录的结果。

PHP数组键值翻转方法性能对比表明:array_flip()函数在大型数组(超过100万个元素)下比for循环性能更优,耗时更短。手动翻转键值的for循环方法耗时相对较长。

PHP中深度复制数组的方法包括:使用json_decode和json_encode进行JSON编码和解码。使用array_map和clone进行深度复制键和值的副本。使用serialize和unserialize进行序列化和反序列化。

多维数组排序可分为单列排序和嵌套排序。单列排序可使用array_multisort()函数按列排序;嵌套排序需要递归函数遍历数组并排序。实战案例包括按产品名称排序和按销售量和价格复合排序。

PHP的array_group_by函数可根据键或闭包函数对数组中的元素分组,返回一个关联数组,其中键是组名,值是属于该组的元素数组。

在PHP中执行数组深度复制的最佳实践是:使用json_decode(json_encode($arr))将数组转换为JSON字符串,然后再将其转换回数组。使用unserialize(serialize($arr))将数组序列化为字符串,然后将其反序列化为新数组。使用RecursiveIteratorIterator迭代器对多维数组进行递归遍历。

目录Astar Dapp 质押原理质押收益 拆解潜在空投项目:AlgemNeurolancheHealthreeAstar Degens DAOVeryLongSwap 质押策略 & 操作“AstarDapp质押”今年初已升级至V3版本,对质押收益规则做了不少调整。目前首个质押周期已结束,第二质押周期的“投票”子周期刚开始。要获取“额外奖励”收益,需把握此关键阶段(预计持续至6月26日,现余不到5天)。我将细致拆解Astar质押收益,

PHP数组去重算法的复杂度:array_unique():O(n)array_flip()+array_keys():O(n)foreach循环:O(n^2)
