zoukankan      html  css  js  c++  java
  • DataStructure-链表实现指数非递减一元多项式的求和

      1 // 2-链表实现多项式的求和.cpp : 定义控制台应用程序的入口点。
      2 //
      3 #include "stdafx.h"
      4 #include<stdio.h> 
      5 #include<stdlib.h > //使用malloc的时候使用的头文件 
      6 typedef int ElementType;
      7 typedef struct Node{
      8     ElementType coef;
      9     ElementType exp;
     10     struct Node * Next;
     11 } List;
     12 
     13 List *InitialEmpty(List* PtrL)
     14 {
     15     PtrL->coef = 0;
     16     PtrL->exp = 0;
     17     PtrL->Next = NULL;
     18     return PtrL;
     19 }
     20 void DispList(List* p){
     21     while (p){
     22         printf("%d,%d ", p->coef, p->exp);
     23         p = p->Next;
     24     }
     25     printf("
    ");
     26 }
     27 List * InsertAsEndNode(ElementType coef, ElementType exp, List*PtrL) {//往PtrL后面插入coef, exp
     28     List *tmp, *pre;
     29     pre = PtrL;//获取首地址 
     30 
     31     while (pre->Next){//找到最后一个节点 
     32         pre = pre->Next;
     33     }
     34     if (pre == NULL)
     35         return NULL;
     36     tmp = (List*)malloc(sizeof(List));//创建一个空间用来存放
     37     tmp->coef = coef;
     38     tmp->exp = exp;
     39     tmp->Next = NULL;
     40     pre->Next = tmp;//将temp插入到pre后面
     41     return PtrL;
     42 }
     43 
     44 void Attach(ElementType coef, ElementType exp, List* PtrL){//
     45     List *p;
     46     p = (List*)malloc(sizeof(List));
     47     p->coef = coef;
     48     p->exp = exp;
     49     p->Next = NULL;
     50     PtrL->Next = p;
     51     //PtrL = PtrL->Next;
     52 }
     53 //单链表排序程序 从小到大排序 
     54 List * Add_List(List* pa, List* pb){
     55     List *h1,*h2,*p3, *h3;
     56     int exp1, exp2;
     57     ElementType sum;
     58     p3 = (List*)malloc(sizeof(struct Node));
     59     p3->coef = 0;
     60     p3->exp = 0;
     61     h1 = pa;
     62     h2 = pb;
     63     h3 = p3;
     64     while (h1&&h2){
     65         exp1 = h1->exp;
     66         exp2 = h2->exp;
     67         if (exp1<exp2){
     68             Attach(h1->coef,h1->exp,h3);
     69             h1 = h1->Next;
     70             h3 = h3->Next;
     71         }
     72         else if (exp1>exp2){
     73             Attach(h2->coef, h2->exp, h3);
     74             h2 = h2->Next;
     75             h3 = h3->Next;
     76         }
     77         else{
     78             sum = h1->coef + h2->coef;
     79             if (sum != 0){
     80                 Attach(sum, h1->exp, h3);
     81                 h3 = h3->Next;
     82             }
     83             h1 = h1->Next;
     84             h2 = h2->Next;
     85             }
     86     }
     87     //h3 = h3->Next;
     88     for (; h1; h1 = h1->Next)
     89     {
     90         Attach(h1->coef, h1->exp, h3);
     91         h3 = h3->Next;
     92     }
     93     for (; h2; h2 = h2->Next)
     94     {
     95         Attach(h2->coef, h2->exp, h3);
     96         h3 = h3->Next;
     97     }
     98     p3 = p3->Next;
     99     return p3;
    100 }
    101 
    102 
    103 
    104 int main(){
    105     int M, N;
    106     ElementType coef, exp;
    107     int cnt1 = 0;
    108     List *pa = (List*)malloc(sizeof(List));//首先必须要有一个内存空间的 
    109     pa = InitialEmpty(pa);//初始化这个头结点 
    110     List *pb = (List*)malloc(sizeof(List));//首先必须要有一个内存空间的 
    111     pb = InitialEmpty(pb);//初始化这个头结点 
    112     List *pc = (List*)malloc(sizeof(List));//首先必须要有一个内存空间的 
    113     pc = InitialEmpty(pc);//初始化这个头结点 
    114 
    115     scanf_s("%d", &M);
    116     for (cnt1 = 0; cnt1<M; cnt1++) {
    117         scanf_s("%d %d", &coef, &exp);//循环在链表后面插入数
    118         InsertAsEndNode(coef, exp, pa);
    119         
    120     }
    121 
    122 
    123     scanf_s("%d", &N);
    124     for (cnt1 = 0; cnt1<N; cnt1++) {
    125         scanf_s("%d%d", &coef, &exp);//循环在链表后面插入数
    126         InsertAsEndNode(coef, exp, pb);
    127         
    128     }
    129     pc = Add_List(pa, pb);
    130     DispList(pc);
    131     return 0;
    132 }
    View Code
  • 相关阅读:
    COJ979 WZJ的数据结构(负二十一)
    COJ980 WZJ的数据结构(负二十)
    奇怪的错误
    COJ883 工艺品
    COJ885 LCS???
    COJ559 回文
    hdu1505(dp求最大子矩阵)
    hdu1506(dp求最大子矩阵)
    hdu2569(递推dp)
    hdu1081(最大子矩阵)
  • 原文地址:https://www.cnblogs.com/robohou/p/8822402.html
Copyright © 2011-2022 走看看