C语言-报数出圈问题(链表实现)

问题描述:n个人围成一圈,顺序编号。从第一个人开始从1到m报数,凡报到m的人退出圈子,编程求解最后留下的人的初始编号。
程序运行示例:
6 3(两个输入数据之间有空格)
1

输入格式:scanf("%d%d",&n,&m);
输出格式:printf("%d\n",p->data);

解决方法:该问题用单链表的方法建立链表存储人数和序号,通过连接首尾达到循环的效果,删除n-1个元素只留一个元素后输出剩余的唯一一个元素,即最后一个元素。

#include<stdio.h>
#include<stdlib.h>
#include<string.h>

typedef struct Node{
	int data;
	struct Node* next;
}S;

S* head_create(){
	S* head = (S*)malloc(sizeof(S));
	if(head==NULL) exit(1);
	head->next=NULL;
	return head;
}

S* Node_insert(S* head,int i,int x){//插入数据 
	S *p;p=head;
	int m=0;
	while(m<i-1){
		p=p->next;
		m++;
	}
	S* q = (S*)malloc(sizeof(S));
	q->next=p->next;
	p->next=q;
	q->data=x;
}
S* xunhuan(S* head){//将链表的第一个元素与最后一个元素连接 
	S *p;p=head;
	while(p->next){
		p=p->next;
	} 
	p->next = head->next;
} 
S* Node_delete(S* head,int i){//每次删除后返回删除元素前一个元素 
	S *p,*s;p=head;
	int m=0;
	while(m<i-1){
		p=p->next;
		m++;
	}
	s=p->next;
	p->next = s->next;
	free(s);
	return p;
}

void print_SL(S *head,int i)//打印出链表中唯一元素,i>1时会重复输出链表中剩余元素 
{
	S *p;p=head;
	if(p==NULL) printf("单链表空!\n");
    else{
		p=p->next;
	}
	int m=0;
	while(m<i)
	{
		printf("%d",p->data);
		p=p->next;
		m++;
	}
}

main(){
	int m,n,i;
	S *s1=head_create();
	//输入mn 
	scanf("%d%d",&m,&n);
	for(i=1;i<=m;i++){
		Node_insert(s1,i,i);
	} 
	xunhuan(s1);
	for(i=1;i<m;i++){
		s1=Node_delete(s1,n);
	}
	print_SL(s1,1);
	return 0;
}

运行结果:

 

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yyq小白鼠

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值