#include<iostream>
#include<string.h>
#include<cstdio>
#include <sstream>
using namespace std;
template <class T>
class joseph
{
struct node
{
T data;
node * next;
node():next(NULL) {}
node(T d):data(d),next(NULL) {}
};
private:
node * head;
node * cur;
node * pre; public:
joseph(T d);
int len = 0;
void setValue(T d)
{
node * tem = new node(d);
cur ->next = tem;
tem -> next = head;
cur = cur -> next;
pre = pre -> next;
len++;
}
void out()
{
pre -> next = cur -> next;
cout<<cur -> data<<" ";
delete cur;
cur = pre -> next;
len--;
}
void nextmove()
{
cur = cur -> next;
pre = pre -> next;
}
void init()
{
cur = cur -> next;
pre = pre -> next;
} };
//模板函数:将string类型变量转换为常用的数值类型(此方法具有普遍适用性)
template <class Type>
Type stringToNum(const string& str)
{
istringstream iss(str);
Type num;
iss >> num;
return num;
} template <class T>
joseph<T> :: joseph(T d)
{
head = new node(d);
node * fz = new node();
cur = head;
pre = fz;
pre -> next = head;
}
int main()
{
string z,x;
cout<<"please input n"<<endl;
cout<<"please input m"<<endl;
while(cin>>z>>x)
{
int a = 1 ;//为第一个节点赋值而创建的
int j = 0 ;//j为n的输入判断因子,当j=1时说明输入的n不是int型
int k = 0 ;//k为m的输入判断因子,当j=1时说明输入的n不是int型
joseph<int> dusk(a);//创建第一个节点,并调用构造函数把第一个节点赋值为1
dusk.len++;//链表长度加一
int n , m ;//n为人数,m为密码
int flag = 0;//是否继续
for(int i = 0 ; i < z.length() ; i++)//判断n是不是int型
{
if(z[i]<'0'||z[i]>'9')
{
cout<<"n input error"<<endl;
j = 1;
flag = 1;
break;
}
}
n = stringToNum<int>(z);//调用函数把string型的n转换成int型
for(int i = 0 ; i < x.length() ; i++)//判断m是不是int型
{
if(x[i]<'0'||x[i]>'9')
{
cout<<"m input error"<<endl;
k=1;
flag = 1;
break;
}
}
if(flag)
{
cout<<"please input n"<<endl;
cout<<"please input m"<<endl;
continue;
}
m = stringToNum<int>(x);//调用函数把string型的m转换成int型
if(n == 1)
{
cout << 1 << endl;
cout<<"please input n"<<endl;
cout<<"please input m"<<endl;
continue;
}
if(k==1||j==1)break;//判断因子有一个等于1说明:n,m有一个输入的不是int型,结束循环 for(int i = 2 ; i <= n ; i++)//初始化赋值
{
dusk.setValue(i);
}
dusk.init();//把cur指针指向head,把pre的next指向cur
while(dusk.len!=0)//长度不为0时循环
{
for(int i = 1 ; i < m ; i++)//移动
{
dusk.nextmove();
}
dusk.out();
}
cout<<endl;
cout<<"please input n"<<endl;
cout<<"please input m"<<endl;
} }

  

约瑟夫环 c++ 循环输入的更多相关文章

  1. 简单约瑟夫环的循环单链表实现(C++)

    刚刚接触C++以及数据结构,今天做了第一次尝试用C++和数据结构解决问题,问题是基于约瑟夫环问题的简单版. 先来看看约瑟夫环问题的介绍: 约瑟夫环是一个数学的应用问题:已知n个人(以编号1,2,3.. ...

  2. 循环列表的Java实现,解决约瑟夫环问题

    import java.util.Scanner; /** * 循环列表的Java实现,解决约瑟夫环问题 * * @author LIU * */ public class LinkedList { ...

  3. 约瑟夫环(N个人围桌,C语言,数据结构)

    约瑟夫环问题(C语言.数据结构版) 一.问题描述 N个人围城一桌(首位相连),约定从1报数,报到数为k的人出局,然后下一位又从1开始报,以此类推.最后留下的人获胜.(有很多类似问题,如猴子选代王等等, ...

  4. 约瑟夫环问题 --链表 C语言

    总共有m个人在圆桌上,依次报名,数到第n个数的人退出圆桌,下一个由退出人下一个开始继续报名,循环直到最后一个停止将编号输出 #include <stdio.h>#include <s ...

  5. 约瑟夫环简介,问题以及java实现

    问题:一群猴子排成一圈,按1,2,--.,n依次编号.然后从第一只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,再把它踢出去-------.,如此不停的进行下去,直到最后只剩下一只猴 ...

  6. 约瑟夫环的C语言数组实现

    约瑟夫环问题的具体描述是:设有编号为1,2,……,n的n个(n>0)个人围成一个圈,从第1个人开始报数,报到m时停止报数,报m的人出圈,才从他的下一个人起重新报数,报到m时停止报数,报m的出圈, ...

  7. 九度OJ 1189:还是约瑟夫环 (约瑟夫环)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:820 解决:522 题目描述: 生成一个长度为21的数组,依次存入1到21: 建立一个长度为21的单向链表,将上述数组中的数字依次存入链表每 ...

  8. 约瑟夫环问题(Josephus)

    约瑟夫环:用户输入M,N值,从1至N开始顺序循环数数,每数到M输出该数值,直至最后一个元素并输出该元素的值. 一.循环链表:建立一个有N个元素的循环链表,然后从链表头开始遍历并记数,如果计数值为M,则 ...

  9. Java数据结构之单向环形链表(解决Josephu约瑟夫环问题)

    1.Josephu(约瑟夫.约瑟夫环)问题: 设编号为1,2,… n的n个人围坐一圈,约定编号为k(1<=k<=n)的人从1开始报数,数到m 的那个人出列,它的下一位又从1开始报数,数到m ...

随机推荐

  1. delphi编写提取exe文件的ICO图标

    http://www.duote.com/tech/4/11797.html delphi编写提取exe文件的ICO图标 7.0分 出处:天下网吧 时间:2011-08-05 人气:2390 核心提示 ...

  2. 我的常用的Linux命令

    环境:centos7 主要应用Linux命令是为了搭建环境,所以记录一下我的常用的Liunx命令 一.常用目录.文件操作命令 1.显示目录列表命令 ls       显示当前目录下的可见文件 ls - ...

  3. 编程字体Source Code Pro 免费下载

    对于程序员来说,好的字体应该满足的基本条件: 字母和数字易于分辨,如: 英文字母o 和 阿拉伯数字 0 ,或者 英文字母 l 和 阿拉伯数字 1 ,两个单引号 '' 和双引号 ”. 字体等宽,保持对齐 ...

  4. 【ABAP系列】SAP MB5B中FI凭证摘要是激活的/结果可能不正确 的错误

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP MB5B中FI凭证摘要是 ...

  5. python 操作ssh登录

    import paramiko #创建SSH对象 ssh = paramiko.SSHClient() #把要连接的机器添加到known_hosts文件中 ssh.set_missing_host_k ...

  6. [19/05/25-星期六] JavaScript_ 基础知识和基本语法_数据类型

    一.概念 诞生于1995年,刚开始主要用于处理网页中的前端验证(指的是检查用户输入的内容是否符合一定的规则,比如用户名的长度.密码的长度.邮箱格式等). 前身是网景公司的LiveScript语言,傍的 ...

  7. SA & SAM

    后缀数组SA \(sa[i]\)与\(rk[i]\) \(sa[i]\) 表示排名为 \(i\) 的后缀是哪一个(在原串中开头位置). \(rk[i]\)(或\(rank[i]\))表示开头位置是 \ ...

  8. 问题 F: 超超的自闭意思

    问题 F: 超超的自闭意思 时间限制: 1 Sec  内存限制: 128 MB提交: 80  解决: 10[提交] [状态] [命题人:jsu_admin] 题目描述 质数定义为在大于1的自然数中,除 ...

  9. Linux基础命令一(补充)

    echo ls ls–l  ---- ll cd /  根目录 cd ~ cd -   返回上一个目录 env ip addr 显示物理网络地址,缩写:ip a /etc/init.d/network ...

  10. Vue-cli2项目文件目录解析

    前言 不是原创,真的不是原创,主要我是根据CSDN的一篇文章和其他平台上的文章整理而来,在最后我会贴上所有原文的地址,下面正式进入正文. Vue-cli项目文件目录结构 这个是Vue-cli2.0版本 ...