欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 健康 > 养生 > 2024.7.22 作业

2024.7.22 作业

2024/10/24 6:29:07 来源:https://blog.csdn.net/sdhdhdhdh/article/details/140618642  浏览:    关键词:2024.7.22 作业

1、约瑟夫环

代码:

/*******************************************/

文件名:josepro.c

功能:函数内容

/*******************************************/

#include "josepro.h"
NodePtr list_create()
{NodePtr L = (NodePtr)malloc(sizeof(Node));if (NULL == L){printf("创建失败\n");return NULL;}L->len = 0;L->next = L;printf("创建成功\n");return L;
}
int list_empty(NodePtr L)
{return L->next == L;
}
NodePtr apply_node(datatype e)
{NodePtr p = (NodePtr)malloc(sizeof(Node));if (NULL == p){printf("申请失败\n");return NULL;}p->data = e;p->next = NULL;
}
NodePtr list_search_pos(NodePtr L, int pos)
{if (NULL == L || pos < 0 || pos > L->len){printf("查找失败\n");return NULL;}NodePtr q = L;for (int i = 0; i < pos; i++){q = q->next;}return q;
}
int list_insert_tail(NodePtr L, datatype e)
{if (NULL == L){printf("插入失败\n");return -1;}NodePtr q = list_search_pos(L, L->len);NodePtr p = apply_node(e);if (NULL == p){return -1;}p->next = q->next;q->next = p;L->len++;return 0;
}
int list_show(NodePtr L)
{if (NULL == L || list_empty(L)){printf("遍历失败\n");return -1;}NodePtr q = L->next;while (q != L){printf("%c\t", q->data);q = q->next;}printf("\n");return 0;
}
int list_delete_head(NodePtr L)
{if (NULL == L || list_empty(L)){printf("删除失败\n");return -1;}NodePtr p = L->next;L->next = p->next;free(p);p = NULL;L->len--;return 0;
}
void josepho(NodePtr L)
{NodePtr pt = L, q;if (L == NULL){//链表空return;}int l;printf("请输入数到几开始:");scanf("%d", &l);//调整初始位置到需要结点for (int i = 0; i < l; i++){pt = pt->next;}//n个人循环n次,n等于链表长度int n = L->len;int k;printf("请输入数到几出列:");scanf("%d", &k);printf("\n依次出圈的人员编号是:\n");for (int i = 0; i < n; i++){//循环k-1次找到要删除的前一个结点for (int j = 0; j < k - 1; j++){pt = pt->next;//如果找到的是头结点,绕过 (但循环次数加1)if (pt == L){j--;}}// q是要删除的结点q = pt->next;// 如果删除的结点q是头结点,绕过if (q == L){q = L->next;pt = L;}//删除printf("%c\t", q->data);pt->next = q->next; //孤立要删除的节点free(q);            //释放要删除的节点L->len--;}printf("\n");
}
void list_destroy(NodePtr L)
{if (NULL == L){printf("释放失败\n");return;}while (!list_empty(L)){list_delete_head(L);}free(L);L = NULL;printf("销毁成功\n");
}

/*******************************************/

文件名:josepro.h

功能:函数声明

/*******************************************/

#ifndef JOSEPRO_H
#define JOSEPRO_H
#include<stdio.h>
#include<stdlib.h>
typedef char datatype;
typedef struct Node
{union{int len;datatype data;};struct Node *next;
}Node,*NodePtr;
NodePtr list_create();
int list_empty(NodePtr L);
NodePtr apply_node(datatype e);
NodePtr list_search_pos(NodePtr L,int pos);
int list_insert_tail(NodePtr L,datatype e);
int list_show(NodePtr L);
int list_delete_head(NodePtr L);
void josepho(NodePtr L);
void list_destroy(NodePtr L);
#endif

/*******************************************/

文件名:main.c

功能:函数内容

/*******************************************/

#include "josepro.h"
int main(int argc, char const *argv[])
{NodePtr L = list_create();if (NULL == L){return -1;}list_insert_tail(L, 'a');list_insert_tail(L, 'b');list_insert_tail(L, 'c');list_insert_tail(L, 'd');list_insert_tail(L, 'e');list_insert_tail(L, 'f');list_insert_tail(L, 'g');list_insert_tail(L, 'h');list_insert_tail(L, 'i');list_insert_tail(L, 'j');list_insert_tail(L, 'k');list_show(L);josepho(L);list_destroy(L);L = NULL;return 0;
}

结果:

2、进制转换

代码:

/*******************************************/

文件名:josepro.c

功能:函数内容

/*******************************************/

#include "jinzhi.h"
StackPtr stack_create()
{StackPtr S = (StackPtr)malloc(sizeof(Stack));if (NULL == S){printf("创建失败\n");return NULL;}S->data = (datatype *)malloc(sizeof(datatype) * MAX);if (NULL == S->data){printf("创建失败\n");return NULL;}bzero(S->data, sizeof(datatype) * MAX);S->top = -1;printf("创建成功\n");return S;
}
int stack_empty(StackPtr S)
{return S->top == -1;
}
int stack_full(StackPtr S)
{return S->top == MAX - 1;
}
void stack_push(StackPtr S, datatype e)
{if (NULL == S || stack_full(S)){printf("入栈失败\n");return;}S->top++;S->data[S->top] = e;printf("入栈成功\n");
}
void stack_show(StackPtr S)
{if (NULL == S || stack_empty(S)){printf("遍历失败\n");return;}printf("该数的进制切换结果是:");for (int i = S->top; i >= 0; i--){printf("%d", S->data[i]);}printf("\n");
}
void stack_destroy(StackPtr S)
{if (S != NULL){free(S->data);S->data = NULL;free(S);S = NULL;}printf("销毁成功\n");
}
void jinzhi_change(StackPtr S)
{int in = 0;printf("请输入初始十进制数:");scanf("%d", &in);int ch = 0;printf("请输入要转换的进制:");scanf("%d", &ch);int out = 0;int temp = 0;//in最终为0说明已经全部入栈while (in != 0){temp = in % ch;//从最低位入栈,遍历时就会是最后显示stack_push(S, temp);in = in / ch;}
}

/*******************************************/

文件名:josepro.h

功能:函数声明

/*******************************************/

#ifndef JINZHI_H
#define JINZHI_H
#include <stdio.h>
#include <stdlib.h>
typedef int datatype;
#define MAX 20
typedef struct
{datatype *data;int top;
} Stack, *StackPtr;
StackPtr stack_create();
int stack_empty(StackPtr S);
int stack_full(StackPtr S);
void stack_push(StackPtr S, datatype e);
void stack_show(StackPtr S);
void stack_destroy(StackPtr S);
void jinzhi_change(StackPtr S);
#endif

/*******************************************/

文件名:main.c

功能:函数内容

/*******************************************/

#include "jinzhi.h"
int main(int argc, char const *argv[])
{StackPtr S = stack_create();if (NULL == S){return -1;}jinzhi_change(S);stack_show(S);stack_destory(S);S = NULL;return 0;
}

结果:

思维导图:

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com