每隔2个数删除一个数的删数问题

问题:有一个数组a[N]顺序存放0~N-1,要求每隔两个数删掉一个数,到末尾时循环至开头继续进行,求最后一个被删掉的数的原始下标位置。以8个数(N=7)为例:{0,1,2,3,4,5,6,7},0->1->2(删除)->3->4->5(删除)->6->7->0(删除),如此循环直到最后一个数被删除。

输入:数组的长度,如8;输出:6

下面是我的解决办法:

说明:countDel用来算删除的数的个数;count用来计算两数的间隔;i 是遍历数组的游标; l(length)是数组的长度

采用下标标记,将删除的数的下标赋值为-1,遍历数组,当遇到值非-1的就用count计数,count累计为3时,说明当前的这个下标对应的数应当被删除(对应的值置为-1),这时也要累计删除的个数countSize并将count清0。

遍历数组时,当游标 i 等于数组长度时,模掉数组长度,如此循环,直到countDel=数组长度时,跳出遍历循环,返回的 i-1  就是最后一个被删除的数的下标。下面附上java的实现:


package com.example.test;

import java.util.Scanner;

/**

* @author Administrator

*/

public class CountIndex {

    public static void main(String[] args) {

      Scanner scanner = new Scanner(System.in);

      int length;

     while (scanner.hasNextInt()) {

            length = scanner.nextInt();

           int[] index = new int[length];

          System.out.println(coutIndex(length, index));

     }

}

public static int coutIndex(int l, int[] index) {

    int i = 0;

    int count = 0;

    int countDel = 0;

    while (true) {

        if (countDel == l) {

           return i - 1;

        }

       if (i == l) {

            i = i % l;

       }

      if (index[i] != -1) {

           count++;

      }

     if (count == 3) {

          count = 0;

          countDel++;

         index[i % l] = -1;

        }

     i++;

    }

  }

}


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Java经典问题算法大全 /*【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子...
    赵宇_阿特奇阅读 6,028评论 0 2
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,359评论 0 33
  • 【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔...
    叶总韩阅读 10,548评论 0 41
  • SwiftDay011.MySwiftimport UIKitprintln("Hello Swift!")var...
    smile丽语阅读 9,398评论 0 6
  • 一个人想要进步,最好最快捷的办法就是离开舒适圈,去一个从没去过的地方,做一些自己从来没有做过的事情。 以前在网易公...
    60476a8c85d4阅读 1,274评论 0 0

友情链接更多精彩内容