问题描述:
有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。
示例:
输入5,输出4
package Test; import java.util.*; public class Main { public static void main(String[] args) { //输入 Scanner sc = new Scanner(System.in); int n = sc.nextInt(); ArrayList<Integer> list = new ArrayList<>(); for (int i = 1; i <= n; i++) { list.add(i); } int count = 0; while (list.size() > 1) { for (int i = 0; i < list.size(); i++) { count++; if (count % 3==0) { System.out.println("第"+list.get(i)+"个人死了"); list.remove(i); i--; } } } System.out.println("留下的是原来第" + (list.get(0))); } }
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/116068.html