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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? polyniomial.cpp

?? 數據結構課程經典源碼
?? CPP
字號:
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
typedef struct Item{
  double  coef;
  int     expn;
  struct Item *next;
  }Item,*Polyn;
#define CreateItem(p) p=(Item *)malloc(sizeof(Item));
#define DeleteItem(p) free((void *)p);
int menu(void);
int PolynNotEmpty(Item *h,char *p);

int Select(char *str)
  { char ch;
    printf("%s\n",str);
    printf("Input Y or N:");
    do{ ch=getch();
	}while(ch!='Y'&&ch!='y'&&ch!='N'&&ch!='n');
    printf("\n");
    if(ch=='Y'||ch=='y') return(1);
    else return(0);
    }
int InsertLocate(Polyn h,int expn,Item **p)
  //查找給定指數expn在指定多項式中是否存在
  //若不存在且指數expn為最小,則返回0和最后一個結點指針
  //若存在,則返回1和對應結點指針
  //若不存在且指數expn值在某兩個結點之間,則返回-1和指數值大于expn結點指針
  { Item *pre,*q;
    pre=h;
    q=h->next;
    while(q&&q->expn>expn) 
      { pre=q;
        q=q->next;
	}
    if(!q)
      { *p=pre;
	return(1);
	}
    else if(q->expn==expn)
      { *p=q;
	return(0);
	}
    else
      { *p=pre;
	return(-1);
        }
    }
        

void insert(Item *pre,Item *p)
{
    p->next=pre->next;
    pre->next=p;
    }
Polyn Input(void)
{
  double  coef;
  int     expn,flag;
  Item *h,*p,*q,*pp;
  CreateItem(h);
  h->next=NULL;
  printf("input coef and expn(if end ,expn=-1)\n");
  while(1)
  {
    scanf("%lf%d",&coef,&expn);
    if(expn==-1) break;
    if(InsertLocate(h,expn,&pp))
     { CreateItem(p);
       p->coef=coef;
       p->expn=expn;
       insert(pp,p);
       }
     else if(Select("has the same expn,Replace older value?"))
	  pp->coef=coef;
     }
  return h;
  }
void Destroy(Polyn h)
{
  Item *p=h,*q;
  while(p!=NULL)
  {
    q=p;
    p=p->next;
    DeleteItem(q);
    }
  }
void Output(Polyn h,char *title)
{
  int flag=1;
  Item *p=h->next;
  printf("%s=",title);
  while(p)
  { if(flag)
      { flag=0;
	if(p->expn==0) 	printf("%.2lf",p->coef);
	else printf("%.2lfx^%d",p->coef,p->expn);
	}
    else
      { if(p->coef>0) printf("+");
	if(p->expn==0) 	printf("%.2lf",p->coef);
	else printf("%.2lfx^%d",p->coef,p->expn);
	}
    p=p->next;
    }
 printf("\n");
 }
Polyn AddPolyn(Polyn h1,Polyn h2) //兩個多項式相加
{
  Item *head,*last,*pa=h1->next,*pb=h2->next,*s,*s0;
  double coef;
  CreateItem(head);
  last=head;
  while(pa&&pb)
    if(pa->expn==pb->expn)
    {
      coef=pa->coef+pb->coef;
      if(coef!=0)
      {
	CreateItem(s);
	s->coef=coef;
	s->expn=pa->expn;
	last->next=s;
	last=s;
	}
      pa=pa->next;
      pb=pb->next;
      }
    else
      {
	if(pa->expn>pb->expn)
	  {
	    s0=pa;
	    pa=pa->next;
	    }
	else
	  {
	    s0=pb;
	    pb=pb->next;
	    }
	CreateItem(s);
	s->coef=s0->coef;
	s->expn=s0->expn;
	last->next=s;
	last=s;
	}
    s0=pa?pa:pb;
    while(s0)
    {
      CreateItem(s);
      s->coef=s0->coef;
      s->expn=s0->expn;
      last->next=s;
      last=s;
      s0=s0->next;
      }
    last->next=NULL;
    return head;
    }
Polyn SubtractPolyn(Polyn h1,Polyn h2)
{ int flag;
  Item *head,*last,*pa=h1->next,*pb=h2->next,*s,*s0;
  double coef;
  CreateItem(head);
  last=head;
  while(pa&&pb)
    if(pa->expn==pb->expn)
    {
      coef=pa->coef-pb->coef;
      if(coef!=0)
      {
	CreateItem(s);
	s->coef=coef;
	s->expn=pa->expn;
	last->next=s;
	last=s;
	}
      pa=pa->next;
      pb=pb->next;
      }
    else
      { if(pa->expn>pb->expn)
	  { flag=1;
	    s0=pa;
	    pa=pa->next;
	    }
	else
	  { flag=-1;
	    s0=pb;
	    pb=pb->next;
	    }
	CreateItem(s);
	s->coef=flag*s0->coef;
	s->expn=s0->expn;
	last->next=s;
	last=s;
	}
    s0=pa?pa:pb;
    flag=pa?1:-1;
    while(s0)
    {
      CreateItem(s);
      s->coef=flag*s0->coef;
      s->expn=s0->expn;
      last->next=s;
      last=s;
      s0=s0->next;
      }
    last->next=NULL;
    return head;
    }
Polyn MultPolyn(Polyn h1,Polyn h2)
{ int item,expn;
  Item *head,*pa,*pb=h2->next,*s,*pp;
  double coef;
  CreateItem(head);
  head->next=NULL;
  while(pb)
    { pa=h1->next;
      while(pa)
       { coef=pa->coef*pb->coef;
	 expn=pa->expn+pb->expn;
	 if( InsertLocate(head,expn,&pp))
	  { CreateItem(s);
	    s->coef=coef;
	    s->expn=expn;
	    insert(pp,s);
	    }
	  else pp->coef=pp->coef+coef;
	  pa=pa->next;
	  }
       pb=pb->next;
       }
    return head;
    }

void main()
{ int num;
  Polyn  h1=NULL; //p(x)
  Polyn  h2=NULL; //Q(x)
  Polyn  h3=NULL; //P(x)+Q(x)
  Polyn  h4=NULL; //P(x)-Q(x)
  Polyn  h5=NULL; //P(x)*Q(x)
  while(1)
    { num=menu();
      getchar();
      switch(num)
       {
	 case 1:
	    if(h1!=NULL)
	      { if(Select("P(x) is not Empty,Create P(x) again?"))
		 { Destroy(h1);
		   h1=Input();
		   }
		}
	    else h1=Input();
            break;
	 case 2:
	    if(h2!=NULL)
	      { if(Select("Q(x) is not Empty,Create Q(x) again?"))
		 { Destroy(h2);
		   h2=Input();
		   }
		}
	    else h2=Input();
	    break;
	 case 3:
	    if(PolynNotEmpty(h1,"p(x)")&&PolynNotEmpty(h2,"Q(X)"))
	      {h3=AddPolyn(h1,h2);
	       Output(h3,"P(x)+Q(X)");
               printf("P(x)+Q(x) has finished!\n");
	       getchar();
               }
	    break;
	 case 4:
	    if(PolynNotEmpty(h1,"p(x)")&&PolynNotEmpty(h2,"Q(X)"))
	      { h4=SubtractPolyn(h1,h2);
	        Output(h4,"Px)-Q(x)");
                printf("P(x)-Q(x) has finished!\n");
		getchar();
		}
	    break;
	 case 5:
            if(PolynNotEmpty(h1,"p(x)")&&PolynNotEmpty(h2,"Q(X)"))
	      { h5=MultPolyn(h1,h2);
                Output(h5,"P(x)*Q(x)");
	        printf("P(x)*Q(x) has finished!\n");
	        getchar();
                }
	    break;
         case 6:
	    if(PolynNotEmpty(h1,"p(x)"))
	       { Output(h1,"P(x)");
		 getchar();
		 }
	    break;
	 case 7:
	    if(PolynNotEmpty(h2,"Q(x)"))
	      { Output(h2,"Q(x)");
		getchar();
		}
	    break;
	 case 8:
	    if(PolynNotEmpty(h3,"P(x)+Q(x)"))
	      { Output(h3,"P(x)+Q(x)");
		getchar();
		}
	    break;
	 case 9:
	    if(PolynNotEmpty(h4,"P(x)-Q(x)"))
	      { Output(h3,"P(x)-Q(x)");
		getchar();
		}
	    break;
	 case 10:
	    if(PolynNotEmpty(h5,"P(x)*Q(x)"))
	      { Output(h3,"P(x)*Q(x)");
		getchar();
		}
	    break;
	 case 11:
	    if(h1!=NULL) Destroy(h1);
	    if(h2!=NULL) Destroy(h2);
	    if(h3!=NULL) Destroy(h3);
	    if(h4!=NULL) Destroy(h4);
	    if(h5!=NULL) Destroy(h5);
	 }
      if(num==11) break;
      }
  getch();
  }
int menu(void)
  { int num;
    clrscr();
    printf("%20c1--create P(x)\n",' ');
    printf("%20c2--create Q(x)\n",' ');
    printf("%20c3--p(x)+Q(x)\n",' ');
    printf("%20c4--P(x)-Q(x)\n",' ');
    printf("%20c5--p(x)*Q(x)\n",' ');
    printf("%20c6--print P(x)\n",' ');
    printf("%20c7--print Q(x)\n",' ');
    printf("%20c8--print P(x)+Q(x)\n",' ');
    printf("%20c9--print P(x)-Q(x)\n",' ');
    printf("%20c10--print P(x)*Q(x)\n",' ');
    printf("%20c11--Quit\n",' ');
    printf("         please select 1,2,3,4,5,6,7,8,9,10,11:");
      do{
	  scanf("%d",&num);
	  }while(num<1 || num>11);
    return(num);
    }
int PolynNotEmpty(Polyn h,char *p)
  { if(h==NULL)
      { printf("%s is not exist!\n",p);
        getchar();
	return(0);
	}
     else return(1);
     }
       
  

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产麻豆成人传媒免费观看| 国产jizzjizz一区二区| 久久99精品国产麻豆不卡| 成人黄色片在线观看| 制服丝袜在线91| 国产精品电影院| 精品一区二区影视| 欧美日韩黄色一区二区| 欧美国产精品专区| 久久er精品视频| 欧美日韩免费在线视频| 国产精品电影院| 国产**成人网毛片九色| 51精品秘密在线观看| 一区二区三区日韩精品| 国产成人精品免费一区二区| 日韩欧美在线123| 亚洲18影院在线观看| 色婷婷久久久久swag精品| 国产精品少妇自拍| 国产一区二区不卡在线| 精品国精品国产| 美女www一区二区| 欧美精品自拍偷拍| 亚洲超丰满肉感bbw| 色婷婷综合久久久中文字幕| 国产精品久久久久婷婷二区次| 国产老妇另类xxxxx| 久久亚洲综合色一区二区三区| 蜜桃av一区二区在线观看| 欧美日韩国产一二三| 亚洲香肠在线观看| 欧美日韩一区二区不卡| 亚洲国产精品久久艾草纯爱| 欧美视频一区二| 亚洲成年人网站在线观看| 日本伦理一区二区| 亚洲最新在线观看| 欧美在线看片a免费观看| 夜夜精品视频一区二区| 欧美高清dvd| 国产一区二区中文字幕| 国产午夜精品一区二区三区视频 | 国产婷婷色一区二区三区四区| 免费三级欧美电影| 欧美v亚洲v综合ⅴ国产v| 裸体歌舞表演一区二区| 精品999在线播放| 国产福利视频一区二区三区| 国产精品视频免费看| 91黄视频在线观看| 日韩av一区二区在线影视| 日韩欧美中文一区二区| 国产成人精品亚洲日本在线桃色| 中文字幕一区二区三区乱码在线| 色综合久久88色综合天天6| 夜夜精品视频一区二区| 欧美大片在线观看| 成人在线视频一区二区| 日韩av电影免费观看高清完整版在线观看| 欧美日韩成人综合在线一区二区| 日本 国产 欧美色综合| 欧美激情中文不卡| 色婷婷精品大在线视频 | 欧美性猛交xxxx黑人交| 蜜桃视频一区二区| 欧美激情艳妇裸体舞| 欧美日韩综合色| 国产激情一区二区三区| 亚洲精品欧美综合四区| 日韩欧美一区二区在线视频| 国产成人精品免费一区二区| 午夜不卡av免费| 国产清纯美女被跳蛋高潮一区二区久久w | 国产成人免费av在线| 伊人色综合久久天天人手人婷| 日韩精品在线看片z| 国产精品18久久久久久久网站| 亚洲精品中文字幕在线观看| 国产福利一区二区三区| 香蕉久久夜色精品国产使用方法| 久久久一区二区三区| 色av成人天堂桃色av| 国产在线播放一区| 亚洲福利视频一区| 国产精品夫妻自拍| 欧美tickle裸体挠脚心vk| 欧美性猛交xxxx乱大交退制版| 成人丝袜18视频在线观看| 日韩国产成人精品| 亚洲精品乱码久久久久| 欧美国产综合色视频| 亚洲精品一区二区三区福利| 欧美日韩亚洲国产综合| 91网站黄www| 成人精品亚洲人成在线| 国产在线精品一区二区夜色 | 欧美丰满一区二区免费视频 | 国产精品一区二区三区四区| 91精品国产91久久久久久最新毛片| 成人精品一区二区三区四区| 精彩视频一区二区三区| 图片区小说区国产精品视频| 综合欧美一区二区三区| 国产精品嫩草影院com| 欧美日韩国产高清一区二区| 国产高清无密码一区二区三区| 一区二区三区 在线观看视频| 久久久久99精品国产片| 精品久久人人做人人爰| 91精品久久久久久蜜臀| 欧美久久免费观看| 欧美日韩电影在线| 欧美日韩亚洲高清一区二区| 欧美久久免费观看| 欧美精品vⅰdeose4hd| 欧美久久久久久久久中文字幕| 欧美日韩一区不卡| 欧美放荡的少妇| 欧美一区二区观看视频| 欧美一区二区三区免费大片| 欧美一区二区三区思思人| 日韩视频在线永久播放| 日韩欧美美女一区二区三区| 久久综合一区二区| 国产午夜精品久久久久久免费视| 国产午夜精品一区二区| 亚洲欧洲av色图| 亚洲一区二区三区四区在线| 亚洲综合一区二区| 日本欧洲一区二区| 韩国精品免费视频| 成人av在线播放网址| 色综合久久综合网97色综合| 欧美剧在线免费观看网站| 日韩欧美高清dvd碟片| 国产午夜亚洲精品午夜鲁丝片| 亚洲青青青在线视频| 午夜精品久久久久久不卡8050| 久久国产成人午夜av影院| 国产精品一区二区果冻传媒| 91久久奴性调教| 欧美成人精品福利| 亚洲日本一区二区三区| 视频精品一区二区| 国产suv精品一区二区三区| 91一区在线观看| 欧美电视剧免费全集观看| 国产精品―色哟哟| 偷窥国产亚洲免费视频| 国产精品77777| 欧美三级三级三级| 国产欧美精品一区二区三区四区 | 91国在线观看| 日韩欧美国产高清| 亚洲天堂福利av| 久久精品国产精品亚洲精品| 97国产一区二区| 久久久噜噜噜久久人人看 | 亚洲三级免费观看| 美国十次了思思久久精品导航| 91丨九色丨国产丨porny| 日韩一级片在线播放| 最近中文字幕一区二区三区| 九九在线精品视频| 在线精品视频一区二区三四| 国产欧美日韩综合| 青青草成人在线观看| 色狠狠桃花综合| 国产欧美在线观看一区| 亚洲成av人片在线观看无码| 99国产欧美另类久久久精品| 久久先锋资源网| 日韩一区精品视频| 日本伦理一区二区| 国产精品乱码一区二三区小蝌蚪| 99久久精品国产精品久久 | 欧美视频完全免费看| 亚洲国产激情av| 黄色日韩网站视频| 欧美一区二区三区四区视频| 亚洲国产人成综合网站| 91在线精品一区二区| 国产欧美综合色| 国产成人综合亚洲网站| 欧美成人r级一区二区三区| 午夜av区久久| 欧美日韩国产中文| 亚洲国产一区二区a毛片| 日本黄色一区二区| 国产精品国产三级国产普通话99| 国产成人精品亚洲日本在线桃色 | 成人激情免费网站| 久久婷婷色综合| 国产原创一区二区| 久久综合精品国产一区二区三区| 日韩电影在线免费观看| 欧美一区二区三区四区五区| 蜜臀av性久久久久av蜜臀妖精| 欧美日韩夫妻久久|