当前位置: 首页 > news >正文

一个网站的优化怎么做今天今日头条新闻

一个网站的优化怎么做,今天今日头条新闻,马鞍山网站建设费用,企业邮箱注册哪家好约瑟夫环问题由古罗马史学家约瑟夫(Josephus)提出,他参加并记录了公元66—70年犹太人反抗罗马的起义。在城市沦陷之后,他和40名死硬的将士在附近的一个洞穴中避难。起义者表示“宁为玉碎不为瓦全”,约瑟夫则想“留得青…

        约瑟夫环问题由古罗马史学家约瑟夫(Josephus)提出,他参加并记录了公元66—70年犹太人反抗罗马的起义。在城市沦陷之后,他和40名死硬的将士在附近的一个洞穴中避难。起义者表示“宁为玉碎不为瓦全”,约瑟夫则想“留得青山在不愁没柴烧”。于是,约瑟夫建议41个人排成一个圆圈,由第1个人开始报数,每报数到第3人该人就必须自杀,然后再由下一个重新报数,直到所有人都自杀身亡为止。问:约瑟夫及其朋友应该站在哪个位置?、

        n个人围成一个圆圈,然后从第一个人开始,按:1,2,3,…,m报数,数到m的人出圈,并有出圈者的下一个人重新开始报数,数到m又要出圈,如此类推,直到所有人都出圈,打印出圈的次序,其中n和m为输入数据

        这个问题可以通过数学推理和递归算法来解决。通过不断地计算,可以发现每次移除一个人后,剩下的人重新排列成一个新的圆圈,规模减小并且从下一个人开始。通过不断地递归计算,可以找到最后一个人的位置。

        本篇博客用C语言,利用循环单链表求解约瑟夫环问题。

        引用的头文件

#include<stdio.h>
#include<malloc.h>
#include<time.h>//计算执行时间 

        在main函数中,首先输入总人数count和报数规律num,然后调用Solve_lijie函数求解约瑟夫环问题。为了计算程序执行时间,使用了clock函数来记录开始和结束时刻,然后计算差值得到执行时间。

int main()
{int count, num;double duration; Loop* L;printf("输入总人数count和报数规律num:");scanf("%d%*c%d", &count, &num);//循环单链表求解clock_t start, finish;//长整型数 start = clock();Solve(L, count, num);finish = clock();//记录前后时刻 duration = (double)(finish - start) / CLOCKS_PER_SEC;//这个是有定义的宏 printf("\n使用循环单链表存储所用执行时间:%lf", duration);return 0; } 

结构体定义

typedef int ElemType;
typedef struct Josephus
{ElemType MEN;	struct Josephus* next;
}Loop;
// 循环单链表初始化
void Init(Loop* &L)
{L = (Loop *)malloc(sizeof(Loop));L -> next = L;	// 头尾相连 
}void Create(Loop* &L, int count)
{if(count < 1){printf("介个是个空环\n");return;}Loop *s, *r;Init(L); //初始化头节点 L->MEN = 1; r = L;	//指向头节点 for(int i = 2; i <= count; i++){	//对头节点后面的节点进行初始化并录入数据 Init(s);s->MEN = i;s->next = L;//循环,尾部也是L r->next = s;//r指向头节点 r = s;}
}void Display(Loop* &L)//用于检测是否正常录入数据 
{Loop *p = L;if(L == NULL)return;	printf("报数:\n");do{printf("%d\t", p->MEN);p = p->next;}while(p != L);//兜兜转转回到原点 printf("\n");return; 
}
void Solve(Loop* &L, int count, int num)
{Create(L, count);Display(L);int j;//循环,根据报数规律num让成员出列,受总人数count影响//每杀一个,count--; 每到第num个,就打印后free一个 Loop *p, *r;r=p = L;while(r->next != L)r = r->next;for(int i = count; i > 1; i--){j = 1;do{		r = p;	//形成一前一后两指针 p = p->next;j++;}while(j < num);// 不符合出列条件。此时两指针各下移一个单位r->next = p->next;printf("这个人死了: %d\n", p->MEN);free(p);p = r->next;//符合条件。此时后指针后续链接前指针的后续,释放前指针p,然后恢复前后位置顺序。}printf("获胜者是%d\n", p->MEN);
}

http://www.ritt.cn/news/14717.html

相关文章:

  • 水墨风格的网站最近的疫情情况最新消息
  • php做网站有哪些好处百度营销推广
  • 遵义做网站推广baidu com百度一下
  • 网站建站域名解析最后做企业培训课程种类
  • 27寸显示器网站建设网络营销公司哪家可靠
  • 做网站最好选什么语言百度识图在线
  • 网站开发问题解决磁力狗最佳搜索引擎
  • 苏州教育学会网站建设厦门人才网597人才网
  • 昆山开发区网站制作杭州免费网站制作
  • 网站开发asp软件有哪些西安网站建设排名
  • 有网站是做水果原产地代发的吗cps推广是什么意思
  • 徐州网站制作需要多少钱上海推广seo
  • 网站新闻不添加关键词超链接对优化有影响吗个人模板建站
  • 网站建设创意公司关键词上首页的有效方法
  • 高端的的网站建设公司搜索引擎营销流程是什么?
  • 东莞网站建设案例四川网络推广seo
  • 如何建立一个网站并运行网址链接
  • 响应式网站案例点击精灵seo
  • 网站搭建完手机访问seo关键词排名优化品牌
  • 手机网站怎么做单页面关键词排名零芯互联关键词
  • 营销型网站建设易网拓杭州seo关键字优化
  • 徐州企业制作网站全国网站排名
  • 智能建网站软件seo北京公司
  • 做汽车配件出口用什么网站好些山西seo顾问
  • 宜丰做网站的做竞价推广这个工作怎么样
  • 公司网站维护费怎么做分录企业网址怎么申请
  • 做旅游攻略的网站代码被国家禁止访问的网站怎么打开
  • css3做的网站成都网站快速排名
  • 电子商务网站建设与管理王生春现在最火的推广平台有哪些
  • 做公司网站要营业执照吗百度客服电话号码