去掉第一个数再把第二个放到最后的算法

该算法描述了一种处理数组的技巧,通过删除第一个元素并将第二个元素移到末尾,直至数组只剩两个元素。以数组a[6]={1,2,3,4,5,6}为例,最终结果为b[5]={1,3,4,2,6}。算法通过两层循环实现,外层循环控制删除过程,内层循环用于元素前移。当a[2]为0时,结束循环。" 139106041,7337247,知识图谱详解:原理、算法与实战,"['知识图谱', '深度学习', '数据科学', '自然语言处理', '大数据', '人工智能']
摘要由CSDN通过智能技术生成

    这个算法要实现的功能是:给你一群数,删掉第一个数,再把第二个数放到最后,得到新的一群数,再删掉第一个数,再把第二个数放到最后,重复这些操作,直到只剩两个数,删掉第一个数结束,最后显示所有删掉的数。

    这里我们以数组a[6]={1,2,3,4,5,6}为例,然后把删掉的数放入数组b[ ]中。

    我们先来看看全部的变换过程:

     1 2 3 4 5 6

     3 4 5 6 2

     5 6 2 4

     2 4 6

     6 4

     由此我们可以看出结果b[ 5 ]={1,3,4,2,6},还可以感觉到大概需要两层循环来完成这个算法,外层循环5次,每一次循环表示删掉一个数(把第一个数放入b[ ]数组中),之后把第二个数放到最后,把所有数往前移两位形成一个新的数组,完成这个移位的动作就需要另一次循环了,那么整个程序什么时候停止呢,有很多办法,比如我可以再全部移位之后把最后一个数的再下一位赋为0,那么变换过程如下:

     1 2 3 4 5 6 0

     3 4 5 6 2 0

     5 6 2 4 0

     2 4 6 0

     6

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值