1009: josephus问题
1009: josephus问题
Time Limit: 1 Sec Memory Limit: 64 MB
Submit: 549 Solved: 227
Description
Input
Output
Sample Input
1
9 1 5
Sample Output
5 1 7 4 3 6 9 2 8
8 win.
开学初看得别人用链表来写这道题是云里雾里,而如今已经自己可以写了。(o。o虽然又出现了一堆云雾)
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
typedef struct Link
{
int num;
struct Link *next;
}IA; int n,s,m; IA *Create();
void *Delete(IA *head); int main()
{
//freopen("a.txt","r",stdin);
IA *head=NULL,*tail=NULL;
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d%d",&n,&s,&m);
tail=Create();
Delete(tail);
}
return ;
} IA *Create()
{
IA *head=NULL,*q,*tail;
tail=head;
int i=;
while(i<=n)
{
q=(IA*)malloc(sizeof(IA));
q->num=i;
if(head==NULL)
{
head=q;
tail=q;
tail->next=NULL;
}
else
{
tail->next=q;
q->next=NULL;
tail=q;
}
i++;
}
tail->next=head;
// Print(head);
return tail;
} void *Delete(IA *tail)
{
int cnt=,hui=,i=;//cnt记数,数到m就让此时的人出局;hui记录出局人数
IA *ptr1,*ptr2;
if(tail->next==NULL)
return;
ptr1=tail;
ptr2=tail->next;
while(i!=s)
{
ptr1=ptr2;
ptr2=ptr2->next;
i++;
}
while(hui!=n-)
{
++cnt;
if(cnt==m)
{
printf("%d ",ptr2->num);
ptr1->next=ptr2->next;
free(ptr2);
cnt=;
hui++;
}
else
ptr1=ptr2;
ptr2=ptr1->next;
}
printf("%d\n%d win.\n",ptr1->num,ptr1->num);
} /*void Print(IA *head)
{
IA *p;
if(head==NULL)
return; printf("%d ",head->num);
for(p=head->next;p!=head;p=p->next)
{
printf("%d ",p->num);
}
printf("\n\n");
}*/
循环链表
1009: josephus问题的更多相关文章
- Josephus环类问题,java实现
写出一个双向的循环链表,弄一个计数器,我定义的是到三的时候,自动删除当前节点,很简单. package Com; import java.util.Scanner; /* * 约瑟夫环问题,有n个人组 ...
- HDOJ 1009. Fat Mouse' Trade 贪心 结构体排序
FatMouse' Trade Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- 1009: [HNOI2008]GT考试
1009: [HNOI2008]GT考试 Time Limit: 1 Sec Memory Limit: 162 MB Description 阿申准备报名参加GT考试,准考证号为N位数\(X_1X_ ...
- Josephus环问题
约瑟夫环问题 问题描述: Josephus问题可以描述为如下的一个游戏:N个人编号从1到N,围坐成一个圆圈,从1号开始传递一个热土豆,经过M次传递后拿着土豆的人离开圈子,由坐在离开的人的后面的人拿起热 ...
- Bloomberg面经准备: Josephus problem
Given a circular single linked list.Write a program that deletes every kth node until only one node ...
- 约瑟夫(环)问题(Josephus problem)
问题描述:皇帝决定找出全国中最幸运的一个人,于是从全国选拔出 n 个很幸运的人,让这 n 个人围着圆桌进餐,可是怎么选择出其中最幸运的一个人呢?皇帝决定:从其中一个人从 1 开始报数,按顺序数到第 k ...
- [题解]hdu 1009 FatMouse' Trade(贪心基础题)
Problem Description FatMouse prepared M pounds of cat food, ready to trade with the cats guarding th ...
- josephus Problem 中级(使用数组模拟链表,提升效率)
问题描写叙述: 在<josephus Problem 0基础(使用数组)>中.我们提出了一种最简单直接的解决方式. 可是,细致审视代码之后.发现此种方案的效率并不高,详细体如今.当有人出局 ...
- 终于完成了Josephus的C语言实现啦~~
/*以下程序用来解决Josephus问题,现在只是完成了M>N的情况,2015-08-20 22:22:20*//*发现一个问题:数组的赋值问题:char People[N]={1};并不代表所 ...
随机推荐
- Chrome扩展开发之四——核心功能的实现思路
目录: 0.Chrome扩展开发(Gmail附件管理助手)系列之〇——概述 1.Chrome扩展开发之一——Chrome扩展的文件结构 2.Chrome扩展开发之二——Chrome扩展中脚本的运行机制 ...
- 慢牛系列四:好玩的React Native
在上次随笔(系列三)中,我试着用RN实现了一个Demo,感觉很不错,当时遇到的问题这篇文章里基本都解决了,比如导航动画问题,这篇文章里主要介绍RN的动画,学会动画以后,各种小创意都可以实现了^^ 下面 ...
- IDEA SSH
被IDEA各种虐0.0各种配置,没有人教就百度,别人也弄了点,然后整整花了一天,从eclipse转到IDEA真的不容易啊TT
- WCF 入门 (16)
前言 上周回母校见了一下大学老师,还有些同学,发现差距还是挺大的...圈子不一样,真的就什么都不一样了.. 第16集 WCF中的Soap错误 Soap faults in WCF 首先简单介绍一下什么 ...
- jQuery使用之(一)标记元素属性
jQuery使用主要介绍jQuery如何控制页面,包含元素的属性.css样式风格.DOM模型.表单元素和事件处理等. 标记元素的属性 html中每一个标记都具有一些属性,他们这个标记在页面中呈现各种状 ...
- EasyUI——实现展示后台数据代码
下面是View显示代码: @{ ViewBag.Title = "Index"; Layout = "~/Views/Shared/_Layout.cshtml" ...
- 每天一个linux命令(45):route命令
Linux系统的route 命令用于显示和操作IP路由表(show / manipulate the IP routing table).要实现两个不同的子网之间的通信,需 要一台连接两个网络的路由器 ...
- QQ面向对象设计
通讯项目--仿QQ聊天程序 详细设计说明书 一.引言 此项目为验证Jav ...
- java多线程-Semaphore信号量使用
介绍 信号量(Semaphore),有时被称为信号灯,是在多线程环境下使用的一种设施, 它负责协调各个线程, 以保证它们能够正确.合理的使用公共资源. 概念 Semaphore分为单值和多值两种,前者 ...
- 如何在Dreamweaver中使用emmet
by zhangxinxu from http://www.zhangxinxu.com本文地址:http://www.zhangxinxu.com/wordpress/?p=3666 一.emmet ...