约瑟夫问题总结及代码实现

约瑟夫问题,具体含义通过百度百科/维基百科查阅,分别用数组和链表两种方式实现

注:一下用C++实现,但本质和C一样,只需要在输出、入把cout,cin改成printf,scanf即可

1、用数组实现

主要原理是假设n为总人数,m为间隔,s为起始报数位置,则s = (s+m-1)%n就是第一个出局的人,那么只要把这个人移到最后,s之后的往前移动,n--即可

void Juseph1(int n, int m, int s)
{
int *a = new int[n];//保存n个人的编号(1-n)

        //C语言用a = malloc(sizeof(int)*n)
int i;
int j;
int s1 = s;
int temp;


for(i=0; i<n; i++)
a[i] = i + 1;//a[i]存i+1的编号
for(i=n; i>1; i--)
{
s1 = (s1 + m -1) % i;//s1便是每次循环第一个出局的人
if(s1 == 0)//若循环中最后一人出局就不用往前移了
s1 = i;
temp = a[s1-1];
for(j=s1; j<i; j++)
{
a[j-1] = a[j];
}
a[i-1] = temp;
}


for(i=n; i>0; i--)
{
cout << a[i-1] << " ";

//C语言用printf("%d ", a[i-1])
}
cout << endl;

//C语言用printf("\n" )

delete []a;

//C语言用free(a)
}

2、用链表实现

用单向循环链表实现,n表示总人数,出局一个减一个,直到为1

typedef struct List

{
int data;
struct List *next;
}List;




List *CreatList(int n)
{
List *p = NULL;
List *head = NULL;
List *tail = NULL;
while(n--)
{
p = new List;
cout<<"please input the data of nodes!"<<endl;
cin>>p->data;
p->next = NULL;
if(head == NULL)
{
head = p;
tail = head;
}
else
{
tail->next = p;
tail = p;
}
}
tail->next = head;
return head;
}


void Display(List *head)
{
List *p = head;


while(p->next != head)
{
cout<<p->data<<" ";
p = p->next;
}
cout<<p->data<<endl;
}


void Juseph(List *head, int n,int m, int s)//n个总个数,m为间隔,s为起始位置
{
List *p = head;
List *q = NULL;
List *temp = NULL;
int i = 0;
int j = 0;
while(p->next != head)
{ j++;
if(j == s)
break;
p = p->next;
}
while(n)
{
i++;
if(i == m)
{
cout<<p->data<<" ";
i = 0;
n--;
temp = p->next;
delete p;
q->next = temp;
p = temp;
}
else
{
q = p;
p = p->next;
}
}
cout<<endl;
head = NULL;

}



  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个用于51单片机的超声波避障小车的代码: ```c #include <reg51.h> #define MIDDLE 0 #define LEFT 1 #define RIGHT 2 void Delay450ms() //@11.0592MHz { unsigned char i, j, k; _nop_(); i = 4; j = 39; k = 209; do { do { while (--k); } while (--j); } while (--i); } void Delay150ms() //@11.0592MHz { unsigned char i, j, k; _nop_(); i = 2; j = 13; k = 237; do { do { while (--k); } while (--j); } while (--i); } void Time0Init() { // 初始化定时器0 // ... } void Time1Init() { // 初始化定时器1 // ... } void sgMiddle() { // 设置超声波传感器朝向中间 // ... } void sgLeft() { // 设置超声波传感器朝向左边 // ... } void sgRight() { // 设置超声波传感器朝向右边 // ... } double get_distance() { // 获取超声波传感器测得的距离 // ... } void goForword() { // 小车前进 // ... } void goBack() { // 小车后退 // ... } void Stop() { // 停止小车 // ... } void goRight() { // 小车右转 // ... } void goLeft() { // 小车左转 // ... } void main() { char dir; double disMiddle; // 中间距离 double disLeft; // 左边距离 double disRight; // 右边距离 Time0Init(); // 初始化定时器0 Time1Init(); // 初始化定时器1 sgMiddle(); Delay450ms(); Delay450ms(); dir = MIDDLE; while(1) { if(dir != MIDDLE) { sgMiddle(); Delay450ms(); dir = MIDDLE; } disMiddle = get_distance(); if(disMiddle > 35) { goForword(); } else if(disMiddle < 10) { goBack(); } else { Stop(); sgLeft(); dir = LEFT; Delay450ms(); disLeft = get_distance(); sgMiddle(); Delay450ms(); sgRight(); dir = RIGHT; Delay450ms(); disRight = get_distance(); if(disLeft < disRight) { goRight(); Delay150ms(); Stop(); } if(disLeft > disRight) { goLeft(); Delay150ms(); Stop(); } } } } ``` 这段代码实现了一个超声波避障小车的功能。它使用了51单片机,通过超声波传感器测量距离,并根据距离的变化控制小车的运动。具体的代码逻辑和功能实现请参考上述代码。 #### 引用[.reference_title] - *1* *2* *3* [51单片机实现避障小车](https://blog.csdn.net/m0_68038554/article/details/129938089)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值