首页 > 编程语言 >常见算法

常见算法

时间:2022-12-03 23:14:02浏览次数:47  
标签:pre 常见 next pb 算法 rchild NULL root

  1 //算法
  2 //设计将两个递增有序带头结点链表合并为一个有序递减的链表。
  3 //1,2,3,4,5 
  4 //2,5,9,10 
  5 void MergeList(LinkList &La,LinkList &Lb)
  6 {
  7     LNode *r,*pa=La->next,pb=Lb->next;
  8     La->next=null;//将结果链表La初始化
  9     while(pa&&pb)
 10     {
 11         if(pa->data<=pb->data){
 12             r=pa->next;
 13             pa->next=La->next;//前插入法,所有新插入的结点都在 
 14             La->next=pa;
 15             pa=r; 
 16         }    
 17         else
 18         {
 19             r=pb->next;
 20             pb->next=La->next;
 21             La->next=pb;
 22             pb=r;
 23         }
 24     }    
 25     if(pa){
 26         pb=pa;
 27     }
 28     while(pb)
 29     {
 30         r=pb->next;
 31         pb->next=La->next;
 32         La->next=pb;
 33         pb=r;
 34     }
 35     free(Lb);
 36 } 
 37 
 38 
 39 //BFS广度优先遍历
 40 bool visited[max_vertex];
 41 void BFSTraverse(Graph G)
 42 {
 43     for(i=0;i<G.vexnum;i++){
 44         visited[i]=false;
 45     }
 46     InitQueue(Q);
 47     for(i=0;i<vexnum;i++){
 48         if(!visited[i])
 49             BFS(G,i);
 50     }
 51 }
 52 void BFS(Graph G,int v){
 53     visit(v);
 54     visited[v]=true;
 55     EnQueue(Q,v);
 56     while(!isEmpty(Q))
 57     {
 58         DeQueue(Q,v);
 59         for(w=FirstNeighbor(G,v);w>=0;w=NextNeighBor(G,v,w)){
 60             //检测所有邻结点
 61             if(!visited[w]){
 62                 visit(w);
 63                 visited[w]=true;
 64                 EnQueue(Q,w);
 65             } 
 66         }
 67     }
 68 } 
 69 
 70 //单链表递增输出各结点的数据元素,并释放存储空间
 71 void Min_Delete(LinkList head){
 72     LinkNode *pre_min,*pre;//pre_min指向最小
 73     LinkNode *r;
 74     while(head->next){
 75         pre_min=head;
 76         pre=head->next;
 77         while(pre->next){
 78             if(pre->next->data>pre_min->next->data){
 79                 pre_min=pre;
 80             }
 81         }
 82         r=pre_min->next;
 83         pre_min->next=pre_min->next->next;
 84         free(r);
 85     }
 86     free(head); 
 87 } 
 88 
 89 //二叉树的前中后序递归算法
 90 
 91 void PreOrder(Btree BT){
 92     if(BT != NULL){
 93         cout<<BT->data<<endl;
 94         PreOrder(BT->lchild);
 95         PreOrder(BT->rchild);
 96     }
 97 }
 98 //中序遍历
 99 /*
100 void InOrder(Btree BT) {
101     if (BT != NULL) {
102         InOrder(BT->lchild);
103         cout << BT->data << endl;
104         InOrder(BT->rchild);
105     }
106 }
107 */
108 
109 //后序遍历
110 /*
111 void PostOrder(Btree BT) {
112     if (BT != NULL) {
113         PostOrder(BT->lchild);
114         PostOrder(BT->rchild);
115         cout << BT->data << endl;
116     }
117 }
118 */ 
119 
120 
121 void PreOrderNoRecur(Btree root){
122     stack<Btree> S;
123     while(root!=NULL||!S.empty()){
124     while(root!=NULL)
125     {
126         cout<< root->data<<endl;
127         S.push(root);
128         root=root->lchild; 
129     }
130     }
131     if(!S.empty()){
132         root=S.top();
133         S.pop();
134         root=root->rchild;
135     }
136 }
137 
138 
139 //中序遍历非递归算法
140 /*
141 void InOrderNoRecur(Btree root) {
142     stack<Btree> S;
143     while (root != NULL || !S.empty()) {
144         while (root != NULL) {
145             S.push(root);
146             root = root->lchild;
147         }
148 
149         if (!S.empty()) {
150             root = S.top();
151             cout << root->data << endl;
152             S.pop();
153             root = root->rchild;
154         }
155     }
156 }
157 */
158 
159 //后序遍历非递归算法
160 void PostOrderNoRecur(Btree root) {
161     stack<List> newS;
162     while (root != NULL || !newS.empty()) {
163         while (root != NULL) {
164             List element;
165             element.ptr = root;
166             element.flag = 1;
167             newS.push(element);
168             root = root->lchild;
169         }
170         while (!newS.empty() && newS.top().flag == 2) {
171             cout << newS.top().ptr->data << endl;
172             newS.pop();
173         }
174         if (!newS.empty()) {
175             newS.top().flag = 2;
176             root = newS.top().ptr->rchild;
177         }
178     }
179  }
180  
181  
182 //设计一个算法将二叉树的叶结点按从左到右的顺序连成一个单链表,表头指针head。
183 //叶结点的右指针域来存放单链表指针
184 LinkList head;
185 LinkNode *pre=NULL;
186 LinkList InOrder(BiTree bt)
187 {
188     if(bt){
189         InOrder(bt->lchild);//中序遍历左子树
190         if(bt->lchild=NULL&&bt->rchild=NULL){ //叶结点 
191             if(pre==NULL){ //处理第一个叶结点 
192                 head->next=bt; 
193             } 
194             else{
195                 pre->right=bt;
196             }
197             pre=bt;
198         } 
199     else{
200         InOrder(bt->rchild);//中序遍历右子树 
201     }
202     if(pre){
203         pre->rchild=NULL;//设置链表尾 
204     } 
205     return head; 
206     }
207 }
208 
209 //编写一个利用广度优先搜索算法求解单源最短路径功能
210 void BFS_MIN_Distance(Grapsh G,int u){
211     for(i=0;i<G.vexnul;i++){
212         d[i]=oo;//从u到i结点的最短路径,w不存在
213          
214     }
215     visited[u]=true;
216     d[u]=0;
217     EnQueue(Q,u);
218     while(!isEmpty(Q)){
219         //BFS算法
220         DeQueue(Q,u);
221         for(w=FirstNeighbor(G,u);w>=0;w=NextNeighbor(G,u,w))//检测所有邻接点
222         {
223             if(!visted[w]){
224                 vistted[w]=true;
225                 d[w]=d[u]+1;
226                 EnQueue(Q,w);
227             } 
228          } 
229     } 
230 } 
231 
232 
233 //交换左子树右子树,递归
234 typedef struct BiTNode{
235     ElemType data;
236     BiNode *lchild;
237     BiNode *rchild;
238 }*BiTree,BiTNode;
239 void Exchange(BiTree t){
240     if(t==NULL){
241         retrun;
242     }
243     Exchange(t->lchild);//对左子树进行交换操作
244     Exchange(t->rchild);
245     
246     BiTNode *temp=t->lchild;
247     t->lchild=t->rchild;
248     t->rchild=temp; 
249 }
250 
251 
252 
253 
254 
255 //迪杰斯特拉
256 bool closed[N]={FALSE};
257  int Min[N]={INF};
258 closed[start]=true;//假设从start出发到其余各个点的最短路径
259 Min[start]=0;
260 for(int i=0;i<N;i++){ //将剩余的N-1个顶点距离start的最短路径求出
261     int k=-1;
262     for(int j=1;j<N;++j){
263         if(!closed[j]&&(k=-1||Min[k]>Min[j])){
264             k=j;
265         }
266     } 
267     closed[k]=true;//将k加入已得出结果的集合
268     
269     for(int j=0;j<N;++j){
270         if(!visited[j]){ //更新未求得最短路径的结点得到start的最短距离
271             if(Min[j]>Min[k]+G[k][j]){
272                 Min[j]=Min[k]+G[k][j];
273             } 
274             
275         }
276     } 
277     
278 } 

 

标签:pre,常见,next,pb,算法,rchild,NULL,root
From: https://www.cnblogs.com/donxiao-999/p/16948983.html

相关文章

  • 算法图解笔记
    前言知识第一章,算法简介1.2,二分法查找元素1.2.1,特殊的二分查找第二章,选择排序2.1,内存工作原理2.2.1,链表2.2.2,数组2.2.3,术语2.3,选择排序2.4,小结第......
  • Rsync报错踩坑记录(一):一次小疏忽引发的麻烦及新手会遇到的三种常见报错原因
    Rsync报错踩坑记录(一)1.三种常见报错原因之一:防火墙问题造成该报错的原因是:客户端和服务端防火墙未放行873端口具体会出现如下错误提示:rsync:failedtoconnectto......
  • [信息抽取]基于ERNIE3.0的多对多信息抽取算法:属性关系抽取
    [信息抽取]基于ERNIE3.0的多对多信息抽取算法:属性关系抽取实体关系,实体属性抽取是信息抽取的关键任务;实体关系抽取是指从一段文本中抽取关系三元组,实体属性抽取是指从一段......
  • [信息抽取]基于ERNIE3.0的多对多信息抽取算法:属性关系抽取
    [信息抽取]基于ERNIE3.0的多对多信息抽取算法:属性关系抽取实体关系,实体属性抽取是信息抽取的关键任务;实体关系抽取是指从一段文本中抽取关系三元组,实体属性抽取是指从一段......
  • 数据结构与算法__01--单链表无顺序添加时,节点对象形成封闭环问题,无法添加同一个对象导
    1进行对象是否相同的判断创建辅助节点temp遍历链表,找到最后未到最后,将temp后移当退出while循环时,temp就指向了链表的最后判断add的节点对象是否存在,若存在则不添......
  • CodeReview中常见缩写
    ASAP:AsSoonAsPossible.请尽快完成ACK:Acknowledgement.承认,同意。表示接受代码的改动CR:CodeReview.请求代码审查CCN:CodeCommentsNeeded.需要的代码注......
  • 回溯算法高效需要注意这两点
    回溯算法高效需要注意这两点坚持原创,写好每一篇文章算法的知识点你学习算法的时候有没有感觉很难,为什么学习算法这么难,而你学软件开发的时候感觉很简答很有意思呢?算法......
  • 常见标签
    今天在写jsp文件时,忘记了如何在jsp文件里面添加图片,于是我在网上找了一些常用标签,想在博客里面做一些记录,方便以后查询使用最常见的html文件  形式为以下类型<html......
  • mysql 常见锁的类型(一)
    @[toc]一、锁的分类1.1加锁的目的当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况,若对并发操作不加控制就可能会读取和存储不正确的数据,破......
  • SwiftUI 常见组件示例
    基础组件TextText("Hamlet").font(.largeTitle)Text("byWilliamShakespeare").font(.caption).italic()ImageHStack{Image(systemName:"fol......