- 1、本文档共22页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
算法大全(c,c)算法全(c,c)算法大全(c,c)算法大全(c,c)
算法大全(C,C++)
数论算法 1.求两数的最大公约数 function gcd(a,b:integer):integer;begin if b=0 then gcd:=aelse gcd:=gcd (b,a mod b);end ; 2.求两数的最小公倍数 function lcm(a,b:integer):integer;beginif ab then swap(a,b);lcm:=a;while lcm mod b0 do inc(lcm,a);end; 3.素数的求法 A.小范围内判断一个数是否为质数:function prime (n: integer): Boolean;var I: integer;beginfor I:=2 to trunc(sqrt(n)) doif n mod I=0 then begin prime:=false; exit;end;prime:=true;end; B.判断longint范围内的数是否为素数(包含求50000以内的素数表):procedure getprime;var i,j:longint;p:array[1..50000] of boolean;beginfillchar(p,sizeof(p),true);p[1]:=false;i:=2;while i50000 do beginif p[i] then beginj:=i*2;while j50000 do beginp[j]:=false;inc(j,i);end;end;inc(i);end;l:=0;for i:=1 to 50000 doif p[i] then begininc(l);pr[l]:=i;end;end;{getprime}function prime(x:longint):integer;var i:integer;beginprime:=false;for i:=1 to l doif pr[i]=x then breakelse if x mod pr[i]=0 then exit;prime:=true;end;{prime} 二、图论算法 1.最小生成树 A.Prim算法:
procedure prim(v0:integer);varlowcost,closest:array[1..maxn] of integer;i,j,k,min:integer;beginfor i:=1 to n do beginlowcost[i]:=cost[v0,i];closest[i]:=v0;end;for i:=1 to n-1 do begin{寻找离生成树最近的未加入顶点k}min:=maxlongint;for j:=1 to n doif (lowcost[j]min) and (lowcost[j]0) then beginmin:=lowcost[j];k:=j;end;lowcost[k]:=0; {将顶点k加入生成树}{生成树中增加一条新的边k到closest[k]}{修正各点的lowcost和closest值}for j:=1 to n doif cost[k,j]lwocost[j] then beginlowcost[j]:=cost[k,j];closest[j]:=k;end;end;end;{prim} B.Kruskal算法:(贪心) 按权值递增顺序删去图中的边,若不形成回路则将此边加入最小生成树。function find(v:integer):integer; {返回顶点v所在的集合}var i:integer;begini:=1;while (i=n) and (not v in vset[i]) do inc(i);if i=n then find:=i else find:=0;end; procedure kruskal;vartot,i,j:integer;beginfor i:=1 to n do vset[i]:=[i];{初始化定义n个集合,第I个集合包含一个元素I}p:=n-1; q:=1; tot:=0; {p为尚待加入的边数,q为边集指针}sort;{对所有边按权值递增排序,存于e[I]中,e[I].v1与e[I].v2为边I所连接的两个顶点的序号,e[I].len为第I条边的长度}while p0 do begini:=find(e[q].v1);j:=find(e[q].v2);if ij the
您可能关注的文档
- 四级英语必考单词词汇_带音四级英语必考单词词汇_带音标四级英语必考单词词汇_带音标四级英语必考单词词汇_带音标.doc
- 四级英语常用动词、名词、形词、介词固定搭配四级英语常用动词、名词、形容词、介词固定搭配四级英语常用动词、名词、形容词、介词固定搭配四级英语常用动词、名词、形容词、介词固定搭配.doc
- 四级新题型之段落翻译练习题级新题型之段落翻译练习题四级新题型之段落翻译练习题四级新题型之段落翻译练习题.doc
- 四级英语词汇大纲2007新纲(课堂用)四级英语词汇大纲2007新大纲(课堂用)四级英语词汇大纲2007新大纲(课堂用)四级英语词汇大纲2007新大纲(课堂用).doc
- 四级油路施工总结四级油路施总结工总结.doc
- 四季度宏观政策应该如何走?季度宏观政策应该如何走?四季度宏观政策应该如何走?四季度宏观政策应该如何走?.doc
- 四级专项完形填空四级专项完填空形填空.ppt
- 四季养生之春季养生四季养生春季养生之春季养生.ppt
- 四六级攻略及练习四六级攻略练习及练习.doc
- 四六级改革信息.doc
- 北师大版小学数学三年级上册《寄书》教学设计.docx
- 统编版(部编版)语文二年级上册《雪孩子》教学设计.docx
- 统编版(部编版)语文二年级上册《八角楼上》教学设计.docx
- 北师大版小学数学三年级上册《长方形周长》教学设计.docx
- 北师大版小学数学三年级上册《丰收了》教学设计.docx
- 统编版(部编版)语文二年级上册《夜宿山寺》教学设计.docx
- 统编版(部编版)语文二年级上册《风娃娃》教学设计.docx
- 统编版(部编版)语文二年级上册《朱德的扁担》教学设计.docx
- 统编版(部编版)语文二年级上册《难忘的泼水节》教学设计.docx
- 统编版(部编版)语文二年级上册《纸船和风筝》教学设计.docx
最近下载
- 舞台人生:走进戏剧艺术(中央戏剧学院)超星尔雅学习通章节测试答案.docx
- 《GBT2677.5-1993-造纸原料1%氢氧化钠抽出物含量的测定》.pdf
- 学院科研管理系统需求说明.docx VIP
- 缠师的解盘及回帖整理图文结合92-108..doc
- 国家安全-完整版PPT课件.pptx
- 通信设备施工安全操作规程安全操作规程系列文件 岗位作业指导书 岗位操作规程 .docx VIP
- 动物园安全风险分级管控和隐患排查治理双体系方案全套资料.doc
- 儿童眼保健及常见眼病PPT课件【40页】.pptx
- 媒体传播与舆情监测.pptx VIP
- 贵州省标 - 黔07J102 蒸压加气混凝土砌块建筑构造.pdf
文档评论(0)