亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? 數(shù)據(jù)結(jié)構(gòu)算法集錦.txt

?? 數(shù)據(jù)結(jié)構(gòu)算法集錦:包括大量常用算法
?? TXT
?? 第 1 頁 / 共 3 頁
字號:
                         end;
                        5.高精度除以低精度
                        procedure devide(a:hp;b:longint; var c:hp; var 
                        d:longint);
                         {c:=a div b; d:= a mod b}
                         var i,len:integer;
                         begin
                           fillchar(c,sizeof(c),0);
                           len:=a[0]; d:=0;
                           for i:=len downto 1 do begin
                             d:=d*10+a[i];
                             c[i]:=d div b;
                             d:=d mod b;
                           end;
                           while (len>1) and (c[len]=0) then dec(len);
                           c[0]:=len;
                         end;
                        6.高精度除以高精度
                        procedure high_devide(a,b:hp; var c,d:hp);
                         var
                           i,len:integer;
                         begin
                           fillchar(c,sizeof(c),0);
                           fillchar(d,sizeof(d),0);
                           len:=a[0];d[0]:=1;
                           for i:=len downto 1 do begin
                             multiply(d,10,d);
                             d[1]:=a[i];
                             while(compare(d,b)>=0) do {即d>=b}
                             begin
                               Subtract(d,b,d);
                               inc(c[i]);
                             end;
                           end;
                           while(len>1)and(c.s[len]=0) do dec(len);
                           c.len:=len;
                         end;

                        六、 樹的遍歷
                        1.已知前序中序求后序
                        procedure Solve(pre,mid:string);
                         var i:integer;
                         begin
                           if (pre='''') or (mid='''') then exit;
                           i:=pos(pre[1],mid);
                           solve(copy(pre,2,i),copy(mid,1,i-1));
                           
                        solve(copy(pre,i+1,length(pre)-i),copy(mid,i+1,length(mid)-i));
                           post:=post+pre[1]; {加上根,遞歸結(jié)束后post即為后序遍歷}
                         end;
                        2.已知中序后序求前序
                        procedure Solve(mid,post:string);
                         var i:integer;
                         begin
                           if (mid='''') or (post='''') then exit;
                           i:=pos(post[length(post)],mid);
                           pre:=pre+post[length(post)]; {加上根,遞歸結(jié)束后pre即為前序遍歷}
                           solve(copy(mid,1,I-1),copy(post,1,I-1));
                           
                        solve(copy(mid,I+1,length(mid)-I),copy(post,I,length(post)-i));
                         end;
                        3.已知前序后序求中序的一種
                        function ok(s1,s2:string):boolean;
                         var i,l:integer;   p:boolean;
                         begin
                           ok:=true;
                           l:=length(s1);
                           for i:=1 to l do begin
                             p:=false;
                             for j:=1 to l do
                               if s1[i]=s2[j] then p:=true;
                             if not p then begin ok:=false;exit;end;
                           end;
                         end;
                        procedure solve(pre,post:string);
                          var i:integer;
                          begin
                            if (pre='''') or (post='''') then exit;
                            i:=0;
                            repeat
                              inc(i);
                            until ok(copy(pre,2,i),copy(post,1,i));
                            solve(copy(pre,2,i),copy(post,1,i));
                            midstr:=midstr+pre[1];
                            
                        solve(copy(pre,i+2,length(pre)-i-1),copy(post,i+1,length(post)-i-1));
                          end;

                        七 進(jìn)制轉(zhuǎn)換
                        1.任意正整數(shù)進(jìn)制間的互化
                         除n取余
                        2.實(shí)數(shù)任意正整數(shù)進(jìn)制間的互化
                        乘n取整
                        3.負(fù)數(shù)進(jìn)制:
                            設(shè)計(jì)一個(gè)程序,讀入一個(gè)十進(jìn)制數(shù)的基數(shù)和一個(gè)負(fù)進(jìn)制數(shù)的基數(shù),并將此十進(jìn)制數(shù)轉(zhuǎn)換為此負(fù) 
                        進(jìn)制下的數(shù):-R∈{-2,-3,-4,....-20} 
                        八 全排列與組合的生成
                        1.排列的生成:(1..n)
                        procedure solve(dep:integer);
                           var
                             i:integer;
                           begin
                             if dep=n+1 then begin writeln(s);exit; end;
                             for i:=1 to n do
                               if not used[i] then begin
                                 s:=s+chr(i+ord(''0''));used[i]:=true;
                                 solve(dep+1);
                                 s:=copy(s,1,length(s)-1); used[i]:=false;
                             end;
                           end;
                        2.組合的生成(1..n中選取k個(gè)數(shù)的所有方案)
                        procedure solve(dep,pre:integer);
                           var
                             i:integer;
                           begin
                             if dep=k+1 then begin writeln(s);exit; end;
                             for i:=1 to n do
                               if (not used[i]) and (i>pre) then begin
                                 s:=s+chr(i+ord(''0''));used[i]:=true;
                                 solve(dep+1,i);
                                 s:=copy(s,1,length(s)-1); used[i]:=false;
                             end;
                        end;
                        九.查找算法
                        1.折半查找
                        function binsearch(k:keytype):integer;
                         var low,hig,mid:integer;
                         begin
                           low:=1;hig:=n;
                           mid:=(low+hig) div 2;
                           while (a[mid].key<>k) and (low<=hig) do begin
                             if a[mid].key>k then hig:=mid-1
                               else low:=mid+1;
                             mid:=(low+hig) div 2;
                           end;
                           if low>hig then mid:=0;
                           binsearch:=mid;
                         end;
                        2.樹形查找
                        二叉排序樹:每個(gè)結(jié)點(diǎn)的值都大于其左子樹任一結(jié)點(diǎn)的值而小于其右子樹任一結(jié)點(diǎn)的值。
                        查找
                        function treesrh(k:keytype):pointer;
                         var q:pointer;
                         begin
                           q:=root;
                           while (q<>nil) and (q^.key<>k) do
                             if k<q^.key then q:=q^.left
                             else q:=q^.right;
                            treesrh:=q;
                         end;

                        十、貪心
                        *會(huì)議問題
                        (1) n個(gè)活動(dòng)每個(gè)活動(dòng)有一個(gè)開始時(shí)間和一個(gè)結(jié)束時(shí)間,任一時(shí)刻僅一項(xiàng)活動(dòng)進(jìn)行,求滿足活動(dòng)數(shù)最多的情況。
                        解:按每項(xiàng)活動(dòng)的結(jié)束時(shí)間進(jìn)行排序,排在前面的優(yōu)先滿足。
                        (2)會(huì)議室空閑時(shí)間最少。
                        (3)每個(gè)客戶有一個(gè)愿付的租金,求最大利潤。
                        (4)共R間會(huì)議室,第i個(gè)客戶需使用i間會(huì)議室,費(fèi)用相同,求最大利潤。
                        十一、回溯法框架
                        1. n皇后問題
                        procedure try(i:byte);
                         var j:byte;
                         begin
                           if i=n+1 then begin print;exit;end;
                             for j:=1 to n do
                               if a[i] and b[j+i] and c[j-i] then begin
                                 x[i]:=j;
                              a[j]:=false; b[j+i]:=false; c[j-i]:=false;
                              try(i+1);
                              a[j]:=true; b[i+j]:=true; c[j-i]:=true;
                            end;
                         end;
                        2.Hanoi Tower  漢諾塔
                         h(n)=2*h(n-1)+1 
                         h(1)=1
                         初始所有銅片都在a柱上
                         procedure hanoi(n,a,b,c:byte); {將第n塊銅片從a柱通過b柱移到c柱上}
                         begin
                            if n=0 then exit;
                            hanoi(n-1,a,c,b); {將上面的n-1塊從a柱通過c柱移到b柱上}
                            write(n,’moved from’,a,’to’,c);
                            hanoi(n-1,b,a,c);{ 將b上的n-1塊從b柱通過a柱移到c柱上
                         end;
                         初始銅片分布在3個(gè)柱上,給定目標(biāo)柱goal
                         
                        h[1..3,0..n]存放三個(gè)柱的狀態(tài),now與nowp存最大的不到位的銅片的柱號和編號,h[I,0]存第I個(gè)柱上的個(gè)數(shù)。
                         Procedure move(k,goal:integer); {將最大不到位的k移到目標(biāo)柱goal上}
                         Begin
                         If k=0 then exit;
                         For I:=1 to 3 do
                           For j:=1 to han[I,0] do
                            If h[I,j]=k then begin now:=I;nowp:=j; end; {找到k的位置}
                         If now<>goal then begin  {若未移到目標(biāo)}
                           Move(k-1,6-now-goal);  {剩下的先移到?jīng)]用的柱上}
                           Writeln(k moved from now to goal);
                           H[goal,h[goal,0]+1]:=h[now,nowp]; h[now,nowp]:=0;
                           Inc(h[goal,0]); dec(h[now,0]);
                           Move(k-1,goal); {剩下的移到目標(biāo)上}
                         End;
                        十二、DFS框架
                        NOIP2001 數(shù)的劃分
                        procedure work(dep,pre,s:longint); {入口為work(1,1,n)}
                        {dep為當(dāng)前試放的第dep個(gè)數(shù),pre為前一次試放的數(shù),s為當(dāng)前剩余可分的總數(shù)}
                         var j:longint;
                         begin 
                           if dep=n then begin 
                             if s>=pre then inc(r); exit; 
                           end; 
                           for j:=pre to s div 2 do work(dep+1,j,s-j); 
                         end;
                        類似:
                        procedure try(dep:integer);
                           var i:integer;
                           begin
                             if dep=k then begin
                               if tot>=a[dep-1] then inc(sum);
                                 exit; end;
                             for i:=a[dep-1] to tot div 2 do begin
                               a[dep]:=i; dec(tot,i); 
                        try(dep+1);
                               inc(tot,i);
                             end;
                           end;{try}
                        十三、BFS框架
                        IOI94 房間問題
                        head:=1; tail:=0;
                        while tail<head do begin
                         inc(tail);
                         for k:=1 to n do
                           if k方向可擴(kuò)展 then begin
                             inc(head);
                             list[head].x:=list[tail].x+dx[k];  
                        {擴(kuò)展出新結(jié)點(diǎn)list[head]}
                             list[head].y:=list[tail].y+dy[k];
                             處理新結(jié)點(diǎn)list[head];
                           end;
                        end;

                        十五、數(shù)據(jù)結(jié)構(gòu)相關(guān)算法
                        1.鏈表的定位函數(shù)
                        loc(I:integer):pointer; {尋找鏈表中的第I個(gè)結(jié)點(diǎn)的指針}
                        procedure loc(L:linklist; I:integer):pointer;
                         var p:pointer;
                        j:integer;
                         begin
                        p:=L.head; j:=0;
                        if (I>=1) and (I<=L.len) then 
                         while j<I do begin p:=p^.next; inc(j); end;
                        loc:=p;
                         end;
                        2.單鏈表的插入操作
                        procedure insert(L:linklist; I:integer; x:datatype);
                         var p,q:pointer;
                         begin
                        p:=loc(L,I);
                        new(q);
                        q^.data:=x;
                        q^.next:=p^.next;
                        p^.next:=q;
                        inc(L.len);
                         end;
                        3.單鏈表的刪除操作
                        procedure delete(L:linklist; I:integer);
                         var p,q:pointer;
                         begin
                        p:=loc(L,I-1);
                        q:=p^.next;
                        p^.next:=q^.next;
                        dispose(q);
                        dec(L.len);
                         end;
                        4.雙鏈表的插入操作(插入新結(jié)點(diǎn)q)
                        p:=loc(L,I);
                        new(q);
                        q^.data:=x;
                        q^.pre:=p;
                        q^.next:=p^.next;
                        p^.next:=q;
                        q^.next^.pre:=q;
                        5.雙鏈表的刪除操作
                        p:=loc(L,I); {p為要?jiǎng)h除的結(jié)點(diǎn)}
                        p^.pre^.next:=p^.next;
                        p^.next^.pre:=p^.pre;
                        dispose(p);

                   

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区在线观看视频| 亚洲人成影院在线观看| 国产精品久久久久久久久免费桃花| 亚洲欧美日韩一区二区三区在线观看 | 久久影院电视剧免费观看| 亚洲国产激情av| 亚洲综合av网| 久久se这里有精品| 97久久人人超碰| 欧美精品亚洲二区| 欧美韩国日本综合| 亚洲成av人综合在线观看| 韩国女主播一区二区三区| 91女厕偷拍女厕偷拍高清| 日韩一卡二卡三卡四卡| 国产精品日韩成人| 免费久久99精品国产| 成人97人人超碰人人99| 欧美电影在哪看比较好| 国产精品色眯眯| 日韩精品电影一区亚洲| 成人中文字幕在线| 91精品国产福利在线观看| 欧美高清在线一区| 日日夜夜免费精品| 成人av在线电影| 欧美大尺度电影在线| 亚洲欧美日韩在线播放| 黄色成人免费在线| 欧美日韩久久久| 国产精品国产三级国产a| 毛片av一区二区| 色播五月激情综合网| 久久久美女毛片| 日韩高清不卡在线| 日本伦理一区二区| 亚洲国产精品99久久久久久久久| 日本欧美韩国一区三区| 色婷婷综合久久久中文字幕| 精品国产一区二区三区不卡| 亚洲女性喷水在线观看一区| 国产老女人精品毛片久久| 欧美日韩电影一区| 中文字幕综合网| 国产不卡在线播放| 日韩欧美色综合| 亚洲成人动漫在线免费观看| 99久久久精品| 国产欧美一区二区三区鸳鸯浴| 免费观看在线色综合| 欧美亚洲一区二区在线| 自拍偷拍国产亚洲| 高清国产一区二区| 国产亚洲综合性久久久影院| 青青草成人在线观看| 欧美三级一区二区| 亚洲精品欧美激情| aaa欧美大片| 国产精品九色蝌蚪自拍| 国产在线观看免费一区| 日韩欧美精品三级| 免费的国产精品| 91精品国产一区二区三区香蕉 | 欧美三级一区二区| 亚洲老妇xxxxxx| av在线不卡电影| 国产精品视频看| 福利电影一区二区| 欧美韩日一区二区三区| 国产精品亚洲一区二区三区妖精| 欧美tk丨vk视频| 韩国成人福利片在线播放| 日韩精品中午字幕| 韩国女主播一区| 亚洲精品一区二区三区影院| 蜜臀精品久久久久久蜜臀| 欧美一区二区三区公司| 热久久免费视频| 精品久久一二三区| 国产精品一区免费在线观看| 久久天堂av综合合色蜜桃网| 国产精品亚洲一区二区三区在线| 国产色婷婷亚洲99精品小说| 国产不卡在线播放| 亚洲丝袜精品丝袜在线| 色婷婷国产精品久久包臀| 亚洲一区二区在线播放相泽| 欧美日韩国产高清一区二区三区 | 欧美一区二区日韩| 久久精品av麻豆的观看方式| 精品免费一区二区三区| 国产成人亚洲综合a∨婷婷 | www.99精品| 亚洲视频免费在线| 欧美性一区二区| 日韩精品成人一区二区在线| 欧美大片在线观看一区二区| 国产一区二区三区四区五区入口| 中文字幕免费不卡| 色噜噜偷拍精品综合在线| 午夜免费欧美电影| 精品美女在线播放| 成人激情视频网站| 亚洲午夜久久久久久久久电影网| 7799精品视频| 国产成人精品亚洲777人妖| 亚洲欧美日韩综合aⅴ视频| 欧美日韩小视频| 国内不卡的二区三区中文字幕| 国产午夜一区二区三区| 色8久久精品久久久久久蜜| 日韩 欧美一区二区三区| 国产视频视频一区| 欧美亚洲国产怡红院影院| 免费观看成人鲁鲁鲁鲁鲁视频| 国产喂奶挤奶一区二区三区| 在线免费观看不卡av| 美女视频免费一区| 成人免费视频在线观看| 欧美一区二区视频免费观看| 成人精品亚洲人成在线| 调教+趴+乳夹+国产+精品| 国产日产欧产精品推荐色| 在线亚洲精品福利网址导航| 极品销魂美女一区二区三区| 亚洲日本va午夜在线影院| 日韩三级伦理片妻子的秘密按摩| 成人av在线一区二区| 免费高清成人在线| 亚洲欧洲中文日韩久久av乱码| 日韩视频中午一区| 99久久99久久精品免费观看| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产精品成人免费| 精品久久久久久亚洲综合网| 在线看不卡av| 成人免费视频视频在线观看免费| 日本成人在线视频网站| 亚洲欧美日韩精品久久久久| 2023国产精品| 欧美精品一二三| 91网站最新网址| 国产成人免费高清| 麻豆久久一区二区| 亚洲综合无码一区二区| 国产蜜臀97一区二区三区| 日韩午夜在线观看视频| 色婷婷亚洲精品| 成人午夜av电影| 久久成人免费网站| 亚洲va中文字幕| 亚洲天堂网中文字| 国产调教视频一区| 欧美成人猛片aaaaaaa| 欧美日韩精品三区| 色综合婷婷久久| 成人毛片在线观看| 国产一二三精品| 麻豆国产精品视频| 日韩成人精品在线观看| 亚洲激情图片一区| 国产精品久久久久久户外露出| 久久这里都是精品| 欧美不卡视频一区| 欧美一二三四在线| 在线不卡中文字幕| 在线看国产日韩| 色婷婷精品久久二区二区蜜臂av | 制服丝袜激情欧洲亚洲| 91成人看片片| 成人av在线播放网址| 国产一区二区在线电影| 美腿丝袜在线亚洲一区| 日韩精品一级二级| 首页国产欧美日韩丝袜| 亚洲综合视频网| 一区二区三区四区av| 一区二区高清在线| 亚洲激情欧美激情| 亚洲综合一二区| 亚洲va欧美va国产va天堂影院| 亚洲愉拍自拍另类高清精品| 一区二区久久久| 亚洲综合色在线| 午夜视频在线观看一区二区| 亚洲电影一级片| 天天影视网天天综合色在线播放| 亚洲高清视频在线| 午夜精品福利一区二区蜜股av| 午夜精品国产更新| 老色鬼精品视频在线观看播放| 久久精品国产99久久6| 国模大尺度一区二区三区| 国产精品一区在线| av午夜精品一区二区三区| 92国产精品观看| 欧美色图激情小说| 欧美一区二区三级| 久久精品在线免费观看| 亚洲国产精品成人综合色在线婷婷 |