标题:课程设计终于结束了,现把源程序和报告发上来
只看楼主
shuihan
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2007-9-22
得分:0 
也发我吧
我的是[email]244817985@[/email]谢谢了哦
2007-12-14 08:30
homage
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2007-12-15
得分:0 
发给我好吗?[email]stu_qiao@[/email]
2007-12-15 16:00
听妈妈的话
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2007-12-15
得分:0 
如何学习C语言
怎么学习C语言啊?感觉那背的东东好像挺多的哦!谢谢各位大虾呵呵

love c
2007-12-15 18:45
polka
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2007-6-17
得分:0 
把报告发给我好不?谢谢了,我的邮箱:[email]polkamail@[/email]
2007-12-17 21:43
zhang299
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2007-11-12
得分:0 
我也要一份啊。。。谢谢了。。。。。。[email]zhang443445860@[/email]
2007-12-18 11:48
major57
Rank: 2
等 级:论坛游民
帖 子:18
专家分:20
注 册:2007-11-23
得分:0 
看样子 你学得挺不错的嘛
2007-12-18 15:00
StarWing83
Rank: 8Rank: 8
来 自:仙女座大星云
等 级:贵宾
威 望:19
帖 子:3951
专家分:748
注 册:2007-11-16
得分:0 
帮楼主整理
程序代码:
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
# define LH 1
# define EH 0
# define RH -1
# define TRUE 1
# define FALSE 0
# define MAX 20

int taller=0; /*taller反映T长高与否*/
int shorter=0; /*shorter反映T变矮与否*/

typedef struct BSTNode { /*二叉排序树的类型定义*/
    int data;
    int bf; /*结点的平衡因子*/
    struct BSTNode * lchild, * rchild;
}BSTNode, *BSTree;

BSTree R_Rotate(BSTree p) { /*对以p为根的二叉排序树作右旋处理,处理之p指向新的树根结点*/
    /*即旋转处理之前的左子树根结点*/
    BSTNode *lc;
    lc=p->lchild;
    p->lchild=lc->rchild;
    lc->rchild=p;
    p=lc;
    return p;
} /*R_Rotate*/

BSTree L_Rotate(BSTree p) { /*对以p为根的二叉排序树作左旋处理,处理之p指向新的树根结点*/
    /*即旋转处理之前的右子树根结点*/
    BSTNode *rc;
    rc=p->rchild;
    p->rchild=rc->lchild;
    rc->lchild=p;
    p=rc;
    return p;
}/*L_Rotate*/

BSTree LeftBalance(BSTree T) { /*对以指针T所指结点为根的二叉树作左平衡旋转处理,本算法结束时*/
    /*指针T指向新的根结点*/
    BSTNode *lc,*rd;
    lc=T->lchild;
    switch (lc->bf) {
    case LH:
        T->bf=lc->bf=EH;
        T=R_Rotate(T);
        break;
    case RH:
        rd=lc->rchild;
        switch (rd->bf) {
        case LH:
            T->bf=RH;
            lc->bf=EH;
            break;
        case EH:
            T->bf=lc->bf=EH;
            break;
        case RH:
            T->bf=EH;
            lc->bf=LH;
            break;
        }
        rd->bf=EH;
        T->lchild=L_Rotate(T->lchild);
        T=R_Rotate(T);
    }
    return T;
}

BSTree RightBalance(BSTree T) { /*对以指针T所指结点为根的二叉树作右平衡旋转处理,本算法结束时*/
    /*指针T指向新的根结点*/
    BSTree rc,ld;
    rc=T->rchild;
    switch (rc->bf) {
    case RH:
        T->bf=rc->bf=EH;
        T=L_Rotate(T);
        break;
    case LH:
        ld=rc->lchild;
        switch (ld->bf) {
        case LH:
            T->bf=LH;
            rc->bf=EH;
            break;
        case EH:
            T->bf=rc->bf=EH;
            break;
        case RH:
            T->bf=EH;
            rc->bf=RH;
            break;
        }
        ld->bf=EH;
        T->rchild=R_Rotate(T->rchild);
        T=L_Rotate(T);
    }
    return T;
}

BSTree InsertAVL (BSTree T, int e) { /*若在平衡的二叉排序树T中不存在和e有相同关键字的结点,则插入一个
  /*数据元素为e的新结点,并返回插入后所建成的平衡二叉排序树,否则返回
  /*NULL.若因插入而使二叉数失去平衡,则作平衡旋转处理,布尔变量taller
  /*反映T长高与否*/
    BSTree p;
    if (!T) {
        T=(BSTree)malloc(sizeof(BSTNode));
        T->data=e;
        T->lchild=T->rchild=NULL;
        T->bf=EH;
        taller=TRUE;
    } else {
        if (e==T->data) {
            taller=FALSE;
            return NULL;
        }
        if (e < T->data) {
            p=InsertAVL(T->lchild,e);
            if (p) {
                T->lchild=p;
                if (taller)
                    switch (T->bf) {
                    case LH:
                        T=LeftBalance(T);
                        taller=FALSE;
                        break;
                    case EH:
                        T->bf=LH;
                        taller=TRUE;
                        break;
                    case RH:
                        T->bf=EH;
                        taller=FALSE;
                        break;
                    }
            }
        } else {
            p=InsertAVL(T->rchild,e);
            if (p) {
                T->rchild=p;
                if (taller) {
                    switch (T->bf) {
                    case LH:
                        T->bf=EH;
                        taller=FALSE;
                        break;
                    case EH:
                        T->bf=RH;
                        taller=TRUE;
                        break;
                    case RH:
                        T=RightBalance(T);
                        taller=FALSE;
                        break;
                    }
                }
            }
        }
    }
    return T;
}

BSTree midorder(BSTree T) { /*树的中序遍历的递归算法*/
    if (T!=NULL) {
        midorder(T->lchild);
        printf("%d ",T->data);
        midorder(T->rchild);
    }
}

BSTree RightBalance1(BSTree p) { /*删除结点时对以指针T所指结点为根的二叉树作右平衡旋转处理,本算法结束时*/
    /*指针T指向新的根结点*/
    BSTree p1,p2;
    if (p->bf==-1) {
        p->bf=0;
        shorter=1;
    } else if (p->bf==0) {
        p->bf=1;
        shorter=0;
    } else {
        p1=p->lchild;
        if (p1->bf==0) {
            p->lchild = p1->rchild;
            p1->rchild = p;
            p1->bf=-1;
            p->bf=1;
            p=p1;
            shorter=0;
        } else if (p1->bf==1) {
            p->lchild=p1->rchild;
            p1->rchild=p;
            p1->bf=p->bf=0;
            p=p1;
            shorter=1;
        } else {
            p2=p1->rchild;
            p1->rchild = p2->lchild;
            p2->lchild = p1;
            p->lchild = p2->rchild;
            p2->rchild = p;
            if (p2->bf == 0) {
                p->bf = 0;
                p1->bf = 0;
            } else if (p2->bf == 1) {
                p->bf = -1;
                p1->bf = 0;
            } else {
                p->bf=0;
                p1->bf=1;
            }
            p2->bf=0;
            p=p2;
            shorter=1;
        }
    }
    return p;
}

BSTree LeftBalance1(BSTree p) { /*删除结点时对以指针T所指结点为根的二叉树作左平衡旋转处理,本算法结束时*/
    /*指针T指向新的根结点*/
    BSTree p1,p2;
    if (p->bf==1) {
        p->bf=0;
        shorter=1;
    } else if (p->bf==0) {
        p->bf=-1;
        shorter=0;
    } else {
        p1=p->rchild;
        if (p1->bf==0) {
            p->rchild = p1->lchild;
            p1->lchild = p;
            p1->bf = 1;
            p->bf = -1;
            p = p1;
            shorter = 0;
        } else if (p1->bf==-1) {
            p->rchild=p1->lchild;
            p1->lchild=p;
            p1->bf=p->bf=0;
            p=p1;
            shorter=1;
        } else {
            p2=p1->lchild;
            p1->lchild=p2->rchild;
            p2->rchild=p1;
            p->rchild=p2->lchild;
            p2->lchild=p;
            if (p2->bf==0) {
                p->bf=0;
                p1->bf=0;
            } else if (p2->bf==-1) {
                p->bf=1;
                p1->bf=0;
            } else {
                p->bf=0;
                p1->bf=-1;
            }
            p2->bf=0;
            p=p2;
            shorter=1;
        }
    }
    return p;
}

BSTree Delete(BSTree q, BSTree r) { /*对结点进行删除处理*/
    if (r->rchild==NULL) {
        q->data=r->data;
        q=r;
        r=r->lchild;
        free(q);
        shorter=1;
    } else {
        r->rchild=Delete(q,r->rchild);
        if (shorter==1)
            r=RightBalance1(r);
    }
    return r;
}

BSTree DeleteAVL(BSTree p, int e) { /*找到要删除的结点,并调用删除函数对其进行删除*/
    BSTree q;
    if (p==NULL)
        return NULL;
    else if (e < p->data) {
        p->lchild = DeleteAVL(p->lchild,e);
        if (shorter==1)
            p=LeftBalance1(p);
        return p;
    } else if (e > p->data) {
        p->rchild=DeleteAVL(p->rchild,e);
        if (shorter==1)
            p=RightBalance1(p);
        return p;
    } else {
        q=p;
        if (p->rchild==NULL) {
            p=p->lchild;
            free(q);
            shorter=1;
        } else if (p->lchild==NULL) {
            p=p->rchild;
            free(q);
            shorter=1;
        } else {
            q->lchild=Delete(q,q->lchild);
            if (shorter==1)
                q=LeftBalance1(q);
            p=q;
        }
    }
    return p;
}

/*以上是平衡二叉排序树的建立.增加和删除的函数建立,具体执行在主函数的case 1*/
/*以下是一元多项式的建立输出和相加的函数建立,具体执行在主函数的case 2*/

typedef struct LNode { /*多项式的存储结构定义*/
    int coef;
    int expn;
    struct LNode *next;
}LNode,*linklist;

linklist creat() { /*一元多项式以链表存储形式的建立*/
    linklist head,s,p,pre;
    int coef;
    int expn;
    head=(linklist)malloc(sizeof(LNode));
    head->next=NULL;
    printf("put in coef and expn:");
    scanf("%d %d",&coef,&expn);
    while (coef!=0) {
        s=(linklist)malloc(sizeof(LNode));
        s->coef=coef;
        s->expn=expn;
        s->next=NULL;
        pre=head;
        p=head->next;
        while (p&&p->expn>s->expn) {
            pre=p;
            p=p->next;
        }
        s->next=p;
        pre->next=s;
        printf("put in coef and expn:");
        scanf("%d %d",&coef,&expn);
        printf("\n");
    }
    return head;
}

void print(linklist head) { /*将建立好的一元多项式输出的函数建立*/
    linklist p;
    p=head->next;
    while (p) {
        if (p->next==NULL)
            printf("%dX^%d",p->coef,p->expn);
        else
            printf("%dX^%d+",p->coef,p->expn);
        p=p->next;

    }
}

linklist add(linklist La,linklist Lb) { /*两个一元多项式的加法运算*/
    linklist Lc,pa,pb,pt,pc;
    int temp;
    Lc=(linklist)malloc(sizeof(LNode));
    Lc->next=NULL;
    pa=La->next;
    pb=Lb->next;
    pc=Lc;
    while (pa&&pb) {
        if (pa->expn==pb->expn) {
            pt=(linklist)malloc(sizeof(LNode));
            pt->expn=pa->expn;
            pt->coef=pa->coef+pb->coef;
            pt->next=NULL;
            pa=pa->next;
            pb=pb->next;
        } else if (pa->expn>pb->expn) {
            pt=(linklist)malloc(sizeof(LNode));
            pt->expn=pa->expn;
            pt->coef=pa->coef;
            pt->next=NULL;
            pa=pa->next;
        } else {
            pt=(linklist)malloc(sizeof(LNode));
            pt->expn=pb->expn;
            pt->coef=pb->coef;
            pt->next=NULL;
            pb=pb->next;
        }
        pc->next=pt;
        pc=pt;
    }
    if (pa)
        pc->next=pa;
    else
        pc->next=pb;
    return Lc;
}

linklist mul(linklist La,linklist Lb) { /*两一元多项式的乘法运算*/
    linklist Lc,pa,pb,Temp,pt,pl;
    Lc=(linklist)malloc(sizeof(LNode));
    Lc->next=NULL;
    pa=La->next;
    while (pa) {
        pb=Lb->next;
        Temp=(linklist)malloc(sizeof(LNode));
        Temp->next=NULL;
        pl=Temp;
        while (pb) {
            pt=(linklist)malloc(sizeof(LNode));
            pt->coef=pa->coef*pb->coef;
            pt->expn=pa->expn+pb->expn;
            pt->next=NULL;
            pl->next=pt;
            pl=pt;
            pb=pb->next;
        }
        Lc=add(Lc,Temp);
        pa=pa->next;
    }
    return Lc;
}
int Window() { /*算法运行窗口的建立*/
    int i;
    textmode(C40);
    textbackground(BLUE);
    textcolor(YELLOW);
    clrscr();

    gotoxy(16,4);
    printf("M E N U");
    gotoxy(5,5);
    printf("* * * * * * * * * * * * * * * *");
    for (i=0; i<15; i++) {
        gotoxy(5,i+5);
        putchar('*');
        gotoxy(35,i+5);
        putchar('*');
    }
    gotoxy(5,20);
    printf("* * * * * * * * * * * * * * * *");
    gotoxy(7,8);
    printf("0. Break");
    gotoxy(7,12);
    printf("1. AVL Tree");
    gotoxy(7,16);
    printf("2. Unitary Multionmial");
    gotoxy(5,22);
    printf("Please input your choose:");
    scanf("%d",&i);
    return i;
}
main() {
    int x,i,n,a[MAX];
    char c;
    BSTree T;
    linklist p, q, r;
    x=Window();
    while (x>=0) {
        if (x==0)
            break;
        else if (x==1) {
            clrscr(); /*平衡二叉排序树的建立,增加和删除算法*/
            T=NULL;
            printf("Input the Number of Node:\n");
            scanf("%d",&n);
            printf("Input the BSTree Data:\n");
            for (i=0; i < n; i++) {
                scanf("%d",&a[i]);
            }
            for (i=0; i < n; i++) {
                T=InsertAVL (T,a[i]);
            }
            midorder(T);
            printf("\n");
            printf("Input the num to insert, input \"0\" to finish!\n");
            scanf("%d",&n);
            while (n!=0) {
                T=InsertAVL (T, n);
                scanf("%d",&n);
            }
            printf("\n");
            midorder(T);
            printf("\n");
            printf("Input the num to delete, input \"0\" to finish!\n");
            scanf("%d",&n);
            while (n != 0) {
                T=DeleteAVL (T, n);
                scanf("%d",&n);
            }
            midorder(T);;
            scanf("%c",&c);
            c=getch();
            if (c=='#') {
                x=0;
                break;
            } else
                x=Window();
        }
        if (x==2) { /*一元多项式建立.相加和相乘并对其结果输出的算法*/
            clrscr();
            p=creat();
            q=creat();
            print(p);
            printf("\n");
            print(q);
            r=add(p,q);
            printf("\n");
            print(r);
            r=mul(p,q);
            printf("\n");
            print(r);
            scanf("%c",&c);
            c=getch();
            if (c=='#') {
                x=0;
                break;
            } else
                x=Window();
        }
    }
}

专心编程………
飞燕算法初级群:3996098
我的Blog
2007-12-18 18:32
whui1214
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2008-1-15
得分:0 
感谢楼主,发给我[email]whui1214@[/email]
2008-01-15 17:13
HaPpY随心
Rank: 1
等 级:新手上路
帖 子:119
专家分:0
注 册:2007-9-28
得分:0 
回复 2# 的帖子
谢谢LZ,我的[email]ren0522@[/email]
2008-01-16 07:55
米车阿里
Rank: 1
等 级:新手上路
帖 子:50
专家分:0
注 册:2007-10-19
得分:0 
版主真幽默

天意总有礼物和失落,我享受生命的每个阶段
2008-01-19 21:10



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-42726-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.187391 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved