C++ 字符串编程训练2

今天讲的一道习题是很经典的约瑟夫环问题,其实lz对于链表的某些操作还不是太懂,所以在程序中有些地方还不太看得懂,这里借鉴的网上的做法,还请大牛能够解答我的疑惑,谢谢!

标题:约瑟夫环

说明:约瑟夫环是这么一个问题:已知n个人(编号1,2,。。。n)围坐在圆桌周围。从编号为k的人开始报数,数到m的人出列,他的下一个人又从1开始报数,数到m的人出列,直到所有人都出列。

struct node{

    int num;

    node *next;

};

node *creat(int n)//构建一个链表,即head-》1-》2-》。。。-》n,最后n又回到head
{
    node *p,*q,*head=NULL;
    for(int i=0;i<=n;i++)
    {
     p=new node;
     p->num=i;
     if(head==NULL)
      {
        head=p; //head用0来表示
      }
     else
     {
        q->next=p;
     }
     q=p;
    }
    p->next=head;  //p变为最后一个节点
    return p;
}

int main()

{

   int n,k,m;//n为总人数,k为开始报数的人的序号,m为报到的需要出列的数

   cin>>n>>k>>m;

   node *l,*q;

   l=creat(n);//l即为生成的链表

   q=l;l=l->next;

   for(int i=1;i<k;i++)//这步其实不太理解是什么意思

    {

       q=l;

        l=l->next;

    }

   while(l->next!=l)//l->next==l表示只剩下最后一个人了

   {

      for(int i=1;i<m;i++)//如果还没有报到则依次遍历

       {

           q=l;

            l=l->next;

        }

      cout<<l->num<<"->";//输出出列的人的序号

      q->next=l->next;//将这个人的位置删去

      delete l;

      l=q->next;//用出列的下一个人来代替出列的人

   }

   cout<<l->num;

   delete l;

}

转载于:https://www.cnblogs.com/elninohjh/p/4642292.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/375747.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux扩展lvm磁盘

env&#xff1a; centos 6.5 x64 hyper-v虚拟机 这个方法可以在当前运行的系统中扩展root磁盘 详细步骤 之前想创建的一个虚拟机的磁盘空间不够用了&#xff0c;所以想扩容一下磁盘。 正好使用的时候是lvm磁盘&#xff0c;可以支持扩容。 格式化一个新的分区或者磁盘 Command…

C/C++编译、测试须知、须会,CMake、Boost等

以下内容为本人实习期间学习笔记&#xff01;&#xff01;参考了网上的许多教程&#xff0c;共享大家&#xff0c;欢迎交流。 动态库和静态库&#xff08;共享库&#xff09; 不同点&#xff1a;代码被载入的时刻不同 静态库的代码在编译过程中已经被载入可执行程序&#xf…

C# DataTable去除重复,极其简便、简单

其中sourceDT是获取到的一个DataTable类型的集合对象 去重复使用方式&#xff1a; 实例化一个DataView对象 假设为dv&#xff0c;直接dv.ToTable()即可&#xff0c;ToTable中可为&#xff08;true,"用于判断重复的列"&#xff09;&#xff0c;比如图中所示&#xff0…

【转】C++类中对同类对象private成员访问

私有成员变量的概念&#xff0c;在脑海中的现象是&#xff0c;以private关键字声明&#xff0c;是类的实现部分&#xff0c;不对外公开&#xff0c;不能在对象外部访问对象的私有成员变量&#xff0e; 然而&#xff0c;在实现拷贝构造函数和赋值符函数时&#xff0c;在函数里利…

MySQL 导出命令

mysqldump --no-defaults -u root -p dbname > c:\www\test.sql windows 下使用。转载于:https://www.cnblogs.com/chenshuo/p/4646070.html

ubuntu16.04编译boost for Android(boost 1.65)

下载boost源码 在官网下载指定版本的源码 http://www.boost.org/users/history/ 编译boost源码 1.进入源码目录执行./bootstrap.sh生成编译工具 2.编辑project-config.jam文件,替换如下内容 # define platform name of ndk import os ; if [ os.name ] CYGWIN || [ os.na…

Jquery获取select,dropdownlist,checkbox下拉列表框的值

jQuery获取 Select选择的Text和Value:语法解释&#xff1a;1. $("#select_id").change(function(){//code...}); //为Select添加事件&#xff0c;当选择其中一项 时触发2. var checkText$("#select_id").find("option:selected").text(); //获…

maven2 + tomcat6 + eclipse集成配置

转载&#xff1a;http://wenku.baidu.com/view/d64147c676eeaeaad1f330d4.html?review /*maven2 tomcat6 eclipse集成配置maven的配置环境变量M2_HOME maven主目录环境变量path maven主目录/binapache-maven/conf/setting.xml文件1、新建maven本地仓库文件夹apache-maven2…

定位pure virtual method called问题

我是在进行boost test的时候遇到了这样的一个问题&#xff0c;最后问题定位到测试用例中&#xff0c;测试的工程以及单元测试的代码是之前的&#xff0c;没有开发完&#xff0c;我实习的时候leader让我完善一下测试框架&#xff0c;添加一下测试代码。 目标机是Android&#x…

环形矩阵

1.逆时针 代码&#xff1a; 1 // huanxingjz.cpp : Defines the entry point for the console application.2 //3 4 #include "stdafx.h"5 #include <stdio.h>6 #include <iostream>7 #include "windows.h"8 #define MAX 409 using namespace …

检查MySQL主从数据一致性

未公布转载于:https://www.cnblogs.com/cuizhipeng/p/4646489.html

统计文件里有多少个字符(only a simple cpp)

通过重定向读取文件内容&#xff0c;并检测其中有多少字符&#xff0c;包括空格&#xff0c;但tap键可能统计结果不同。 #include<iostream>int main(int argc,char *argv[]){using std::cin,std::cout,std::endl;cout<<"Usage:"<<argv[0]<<…

Winsock网络编程笔记(4)----基本的理论知识

前面的笔记记录了Winsock的入门编程&#xff0c;领略了Winsock编程的乐趣。。但这并不能算是掌握了Winsock&#xff0c;加深理论知识的理解才会让后续学习更加得心应手。。因此&#xff0c;这篇笔记将记录一些有关Winsock的基本理论知识&#xff0c;由于是一篇笔记&#xff0c;…

30分钟学会使用grunt打包前端代码

http://www.cnblogs.com/yexiaochai/p/3603389.html转载于:https://www.cnblogs.com/wuxiang/p/4647280.html

简单shell:删除五日之前的日志文件

曾经在某公司面试的时候被问到了类似的问题。 假设在logs文件夹存放了许多日志文件 比如&#xff1a;20190204.log、20190205.log、20190206.log。。。 我们要删除特定日期之前的日志 在这里展示的是使用shell指令中的find指令完成操作 首先看一下find指令的命令格式&#xf…

Method Swizzle黑魔法,修改 ios 系统类库方法(转载)

一般来说&#xff0c;系统提供的方法已经足够开发了&#xff0c;但是有的时候有些需求用普通方法不好做。 如&#xff1a;在所有的viewcontroll 的viewwillappear&#xff1a;方法之前打个log 你可能会这么做&#xff1a; 1. 建一个uiviewcontroll 父类&#xff0c;重写viewwil…

win10无法开启夜间模式

在学校的时候没感觉&#xff0c;一进公司发现电脑还是需要设置一下护眼的&#xff0c;但是在设置的时候却遇到夜间模式无法开启的问题。 首先在左下角搜索设备管理器 找到显示适配器 查看显示器设备状态 如果设备图标上有黄三角感叹号则说明该设备驱动有问题&#xff0c;需要…

Linux LVM学习总结——扩展卷组VG

Linux服务器由于应用变更或需求的缘故&#xff0c;有可能出现分区空间不足的情况&#xff0c;此时往往需要进行扩容&#xff08;要增加分区的空间&#xff09;&#xff0c;而采用LVM的好处就是可以在不需停机的情况下可以方便地调整各个分区大小。如下所示&#xff0c;分区/u05…

【液晶模块系列基础视频】1.3.iM_TFT30模块简介

【液晶模块系列基础视频】1.3.iM_TFT30模块介绍 技术论坛&#xff1a;http://www.eeschool.org 博客地址&#xff1a;http://xiaomagee.cnblogs.com 官方网店&#xff1a;http://i-board.taobao.com 银杏科技 GINGKO TECH. 保留权利&#xff0c;转载请注明出处 本次教学视频介…