`
200830740306
  • 浏览: 109428 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

Poj3750 约瑟夫循环

阅读更多
package easy;


import java.io.BufferedInputStream;
import java.util.LinkedList;
import java.util.Scanner;

/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
/**
 *Poj3750 easy 约瑟夫循环
 * @author NC
 */
public class Poj3750 {

    public static void main(String[] args) {
        Scanner scanner = new Scanner(new BufferedInputStream(System.in));
        //用nextInt的话,与下文的nextLine会有点冲突,会报异常,还是统一用一个方法就好
        int n = Integer.parseInt(scanner.nextLine());
        LinkedList<String> queue = new LinkedList();
        for (int i = 0; i < n; i++) {
            String name = scanner.nextLine();
            queue.add(name.trim());
        }
        String ws = scanner.nextLine();
        String[] wss = ws.split(",");
        int w = Integer.parseInt(wss[0]);
        int s = Integer.parseInt(wss[1]);
        int count = 0;
//找出第w个人,从第w个人开始报数
        while (true) {
            count++;
            if (count == n + 1) {
                count = 1;
            }
            if (count == w) {
                break;
            }
            String person = queue.removeFirst();
            queue.add(person);

        }
//从第w个开始报数,报到s的出队
        count = 0;
        while (true) {
            //从1开始报数
            count++;
            if (count == n + 1) {
                count = 1;
            }
            if (queue.isEmpty()) {
                break;
            }
            //出来一个人报数
            String person = queue.removeFirst();
            if (count == s) {
                System.out.println(person);
                count = 0;//出完队后,重新报数
            } else {
                queue.add(person);
            }

        }
    }
}
分享到:
评论

相关推荐

    POJ 1012 约瑟夫问题的数学解法及分析

    POJ 1012 约瑟夫问题的数学解法及分析POJ 1012 约瑟夫问题的数学解法及分析POJ 1012 约瑟夫问题的数学解法及分析

    Josephus 约瑟夫问题(POJ)

    《约瑟夫问题详解及其在POJ中的应用》 约瑟夫问题,源自古罗马历史的一个有趣的故事,是由数学家约瑟夫·弗拉基米尔提出的。问题的基本设定是:一群人站成一个圆圈,从某人开始按顺时针方向计数,每数到特定数值的...

    POJ.rar_poj java_poj1048

    【标题】"POJ.rar_poj java_poj1048" 涉及的知识点主要围绕编程竞赛中的“约瑟夫环”问题,这里是一个加强版,使用Java语言进行解决。 【描述】"POJ1048,加强版的约瑟夫问题 难度中等" 提示我们,这个问题是编程...

    poj1012-Joseph【经典约瑟夫问题】

    标题中的“poj1012-Joseph”是指北京大学在线编程平台POJ(Problemset Online Judge)上的一个问题编号为1012的题目,它与一个著名的算法问题——约瑟夫环(Josephus Problem)相关。约瑟夫环问题源自古罗马历史,是...

    POJ入门题库(含解题思路和答案)

    1. POJ——1004 Financial Management:这可能涉及到基础的数学计算和数据处理,如利润计算、利息计算等,可能需要用到循环结构和简单的数学公式。 2. POJ——1664 放苹果:此题可能需要理解数组操作和动态规划,...

    POJ算法题目分类

    * 图的深度优先遍历和广度优先遍历:图的深度优先遍历和广度优先遍历是指遍历图的两种方式,如 poj1860、poj3259、poj1062、poj2253、poj1125、poj2240。 * 最短路径算法:最短路径算法是指计算图中两点之间的最短...

    POJ2002-Squares

    在AC代码中,会看到这些策略是如何转化为实际的编程逻辑的,比如如何定义变量、如何实现循环和条件语句,以及如何使用C++的库函数。 对于初学者来说,阅读这样的解题报告和代码有助于理解如何将理论知识应用于实际...

    POJ1159-Palindrome

    【标题】"POJ1159-Palindrome" 是北京大学在线编程平台POJ上的一道编程题目。这道题目主要考察的是字符串处理和回文判断的知识点。 【描述】"北大POJ1159-Palindrome 解题报告+AC代码" 暗示了解决这道问题的方法和...

    ACM-POJ 算法训练指南

    1. **状态转移方程**:设计复杂的动态规划状态转移方程(poj1191, poj1054, poj3280, poj2029, poj2948, poj1925, poj3034)。 2. **记忆化搜索**:结合动态规划和递归搜索(POJ3254, poj2411, poj1185)。 3. **...

    poj训练计划.doc

    根据给定的文件信息,我们可以总结出一份详细的IT知识训练计划,主要针对编程竞赛和算法学习,特别是聚焦于POJ(Problem Online Judge)平台上的题目训练。这份计划分为两个阶段,初级阶段和中级阶段,共计涉及了165...

    poj题目分类

    * 较为复杂的动态规划:例如 poj1191、poj1054、poj3280、poj2029、poj2948、poj1925、poj3034。 数学 1. 组合数学: * 加法原理和乘法原理。 * 排列组合。 * 递推关系:例如 poj3252、poj1850、poj1019、poj...

    POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类

    - **例题**:poj1860, poj3259, poj1062, poj2253, poj1125, poj2240 - **解释**:最短路径算法包括Dijkstra算法、Bellman-Ford算法、Floyd算法以及堆优化的Dijkstra算法等。 ##### (3) 最小生成树算法 - **例题**...

    jihe.rar_2289_POJ 3714_poj3714_poj3714 Ra_visual c

    标题中的"jihe.rar_2289_POJ 3714_poj3714_poj3714 Ra_visual c" 提到了一个压缩文件,可能包含有关编程竞赛或算法解决的资源,特别是与POJ(Problem On Judge)平台上的问题3714相关的。"Ra_visual c"可能指的是...

    POJ3253-POJ3253-Fence Repair【STL优先队列】

    标题“POJ3253-POJ3253-Fence Repair【STL优先队列】”指的是一个在线编程竞赛题目,源自北京大学的在线判题系统POJ(Problem Online Judge)。该题目要求参赛者使用C++编程语言解决特定的问题,并且在解决方案中...

    西北工业大学poj

    5. "第二季循环":循环是程序控制流的基础,这部分可能包括for、while等循环结构的运用,以及复杂的循环逻辑设计。 6. "第五季数组":数组是C++中最基本的数据结构之一,这部分可能讲解了数组的初始化、操作、多维...

    poj各种分类

    标题和描述中的“poj各种分类”主要指向的是在POJ(Peking University Online Judge)平台上,根据解题策略和算法类型对题目进行的分类。POJ作为一个知名的在线编程平台,提供了大量的算法练习题,适合从初学者到...

    POJ3122-Pie

    在这个文件中,程序员可能使用了标准库中的数据结构和算法,如数组、指针、循环、条件语句等,来解决问题。 2. "POJ3122-Pie.doc":这可能是解题报告的文档,通常使用Microsoft Word或其他文档编辑软件创建。报告中...

    POJ1019-Number Sequence

    【标题】"POJ1019 - Number Sequence" 是北京大学在线编程平台POJ上的一道算法题目。这道题目主要考察的是数列的理解和计算能力,以及编程解决问题的技巧。 【描述】"北大POJ1019-Number Sequence 解题报告+AC代码...

    POJ1837-Balance

    【标题】"POJ1837-Balance"是一个在线编程竞赛题目,源自著名的编程练习平台POJ(Programming Online Judge)。这个题目旨在测试参赛者的算法设计和实现能力,特别是处理平衡问题的技巧。 【描述】"解题报告+AC代码...

    poj 3414解题报告

    poj 3414解题报告poj 3414解题报告poj 3414解题报告poj 3414解题报告

Global site tag (gtag.js) - Google Analytics