JAVA经典算法50题(13)

时间:2026-01-19

ntln();

for(int i=0;i<m;i++){
brr[i]=arr[n-m+i];
}
for(int i=0;i<n-m;i++){
arr[m+i]=arr[i];
}
for(int i=0;i<m;i++){
arr[i]=brr[i];
}

System.out.println("排序后:");
for(int i=0;i<n;i++){
System.out.print(arr[i]+" ");
}
}
}

【程序37】 题目:有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。
(约瑟夫环问题,百度百科有时间复杂度最简单的数学方法)
原例代码:
import java.util.Scanner;
public class Demo37 {
public static void main(String[] args) {
System.out.println("请输人数n:");
Scanner in = new Scanner(System.in);
int n = in.nextInt();
boolean[] arr = new boolean[n];
for (int i = 0; i < arr.length; i++) {
arr[i] = true; //下标为TRUE时说明还在圈里
}
int leftCount = n;
int countNum = 0;
int index = 0;
while (leftCount > 1) {
if (arr[index] == true) { //当在圈里时
countNum++; //报数递加
if (countNum == 3) { //报数为3时
countNum = 0; //从零开始继续报数
arr[index] = false; //此人退出圈子
leftCount--; //剩余人数减一
}
}
index++; //每报一次数,下标加一
if (index == n) { //是循环数数,当下标大于n时,说明已经数了一圈,
index = 0; //将下标设为零重新开始。
}
}
for (int i = 0; i < n; i++) {
if (arr[i] == true) {
System.out.println(i);
}
}
}
}
个人代码1:
import java.util.Scanner;
public class Demo37 {
public static void main(String[] args) {
System.out.println("请输入人数:");
Scanner in = new Scanner(System.in);
int[] a = new int[in.nextInt()];
for (int i = 0; i < a.length; i++) {
a[i] = 1;
}
int left = a.length;
int j = 0;
int num = 0;
while (left > 1) {
if (a[j] == 1) {
num++;
}
if (num == 3) {
a[j] = 0;
num = 0;
left--;
}
j++;
if (j == a.length) {
j = 0;
}
}
for (int i = 0; i < a.length; i++) {
if (a[i] == 1) {
System.out.println("最后留下的人是"+ (i + 1) + "号");
break;
}
}
}
}
个人代码2:
import java.util.LinkedList;
import java.util.Scanner;
public class Demo37 {
public static void main(String[] args) {
LinkedList<Integer> l = new LinkedList<Integer>();
System.out.println("请输入人数:");
Scanner in = new Scanner(System.in);
int len = in.nextInt();
for (int i = 0; i < len; i++) {
l.add(i + 1);
}
int sum = 0;
int temp = 0;
for (int i = 0; sum != len - 1;) {
if (l.get(i) != 0) {
temp++;
}
if (temp == 3) {
l.remove(i);
l.add(i, 0);
temp = 0;
sum+
+;
}
i++;
if (i == l.size()) {
i = 0;
}
}
for (int t : l) {
if (t != 0) {
System.out.println("最后留下的人是" + t + "号");

…… 此处隐藏:96字,全部文档内容请下载后查看。喜欢就下载吧 ……
JAVA经典算法50题(13).doc 将本文的Word文档下载到电脑

精彩图片

热门精选

大家正在看

× 游客快捷下载通道(下载后可以自由复制和排版)

限时特价:4.9 元/份 原价:20元

支付方式:

开通VIP包月会员 特价:19元/月

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:fanwen365 QQ:370150219