解题思路:循环实现,将数组模拟成一个圈


注意事项:大佬帮忙看看优化,指正思路;

参考代码:

import java.util.Scanner;

public class Demo01 {
   public static void main(String[] args) {
       //     有n人围成一圈,顺序排号。从第1个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来的第几号的那位。
       Scanner sc = new Scanner(System.in);
       int n =sc.nextInt();
       int []arr = new int[n];
       for (int i = 1; i <= arr.length; i++) {
           arr[i-1] = i;
       }
       int[] c = c(arr);
       System.out.println(c[0]);
   }
   public static int[] a(int []arr,int len){
       for (int i = 2; i <= arr.length-len; i+=3) {
           arr[i] = 0;
       }
       return arr;
   }
   public static int[] b(int []ra,int []b ){
       for (int i = 0; i < ra.length; i++) {
           System.out.print("ra:"+ra[i]+" ");
       }
       System.out.println();
       for (int i = 0; i < b.length; i++) {
           System.out.print("b:"+b[i]+" ");
       }
       System.out.println();

       int len = ra.length-(ra.length/3);
       System.out.println("len:"+len);
       int []arr = new int[len];
       if(ra.length%3==0){

           int index = 0;
           for (int i = 0; i < ra.length; i++) {
               if (ra[i] != 0) {
                   arr[index] = ra[i];
                   index++;
               }
           }
       }else {
           for (int i = 0; i < b.length; i++) {
               arr[i] = b[i];
           }
           int index = 0;
           for (int i = 0; i < ra.length-b.length; i++) {
               if(ra[i]!=0){
                   arr[index+ b.length]=ra[i];
                   index++;
               }
           }
       }

       if (arr.length==2) {
           int []arr1 = {arr[1]};
           return arr1;
       }else {
           for (int i = 0; i < arr.length; i++) {
               System.out.print(arr[i]+" ");
           }
           System.out.println();
           return arr;
       }

   }

   public static int[] c(int []arr){
       if(arr.length==1){
           return arr;
       }
       int len = arr.length % 3;
       int[] ra = a(arr, len);
       if(len==0){
          int [] a = new int[2];
           int bIndex = 0;
           for (int i = arr.length-3; i < arr.length-1; i++) {
               a[bIndex] = arr[i];
               bIndex++;
           }
           return c(b(ra,a));
       }else {
           int [] b = new int[len];
           int bIndex = 0;
           for (int i = arr.length-len; i < arr.length; i++) {
               b[bIndex] = arr[i];
               bIndex++;
           }
           return c(b(ra,b));
       }
   }
}

点赞(0)
 

0.0分

3 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论