栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

2021-10-13

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

2021-10-13

HDU1443-java循环双链表实现

题目大意:有2k个人,前k个是好人,后k个是坏人,每隔m个人去除一个人,求k个坏人在好人前全部被去除的最小m。
代码如下:
import java.util.ArrayList;
import java.util.Scanner;

public class HDU1433{
public static void main(String []arges) {
Scanner input = new Scanner(System.in);
ArrayList ans=new ArrayList();
while (!input.hasNext(“0”)) {
int n = input.nextInt();
int m = 1;
joseph j = new joseph(n, m);

            man k = j.first;
            for (int i = 1; i <= j.jlength(); i++) {
                k = k.next;
            }
        ans.add(j.circle(n,m));
    }
    for(int i=0;i

}
class man{
int no;
man next;
man prior;
public man(int num){
no=num;
next=null;
prior=null;
}

}
class joseph{
int n,m;
man first;

public joseph(int n1,int m1){
    man p,t;
    n=n1*2;
    m=m1;
    first=new man(1);
    t=first;
    for(int i=1;i n  && q.jlength()>n) {
            c.prior.next = c.next;
            c.next.prior = c.prior;
            c=c.next;
            for (int i = 1; i < m; i++) {
                c = c.next;
            }

        }
        if ((c.no <= n )&& (q.jlength()>n)) {
            m=m+1;
             q=new joseph(n,m);
            c=q.first;
        }
    }
    return m;
}

}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/325468.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号