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

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

?? fac6_6.java

?? java 算法設(shè)計與分析的好資料.由王曉東先生主編.
?? JAVA
字號:
//本程序取自王曉東編著“算法分析與設(shè)計”第 222 頁,例
//最大團問題的分支限界解法
   
   class MaxHeap 
   {                      //Min-heap impmentation
     static HeapNode[] Heap;  //Pointer to the heap array
     static int size;     //Maximum size of the heap
     static int n;        //Number of intents now in heapheapsoet
    public MaxHeap(HeapNode[] h,int num,int max)//constructor
     { Heap=h;n=num;size=max;buildheap();}
    public int heapsize()//return current size of the heap
     {  return n;}
    public static boolean isLeaf(int pos)//true if pos is a leaf position
     { return(pos>=n/2)&&(pos<n);} 
    public static void Assert_notFalse(boolean p,String q)
     {if(!p)System.out.println((String)q);}
    public static int key( HeapNode [] q,int p)
     {  return q[p].upperSize;}
  //return position for left child of pos
    public static int leftchild(int pos)
     { Assert_notFalse(pos<n/2,"position has no left child");
       return 2*pos+1;
     }
  //return position for right child of pos
    public static int rightchild(int pos)
     {Assert_notFalse(pos<(n-1)/2,"position has no right child");
     return 2*pos+2;
     }
    public static int parent(int pos)//return position for parent
     {Assert_notFalse(pos>0,"position has no parent");
     return (pos-1)/2;
     }
    public static  void buildheap() //Heapify contents of Heap
     {  for(int i=n/2-1;i>=0;i--)siftdown(i);}

    public static void swap(HeapNode[] q,int i,int j)
     {      
       HeapNode temp;
       temp=q[i];q[i]=q[j];q[j]=temp;}

    private static void siftdown(int pos) //put intent in itscorrent place
     {Assert_notFalse((pos>=0) && (pos<n),"illegal heap position ");
     while(! isLeaf(pos))
      {
       int j=leftchild(pos);
       if((j<(n-1))&&(key(Heap,j)<key(Heap,j+1)))
         j++;// j is now index of child with greater value
       if(key(Heap,pos)>=key(Heap,j)) return;// Done
       swap(Heap,pos,j);
       pos=j;//Move down 
      }
     }
    public static void insert(HeapNode val) //Insert value into heap
     {
     Assert_notFalse(n<size,"Heap is full ");
     int curr=n++;
     Heap[curr]=val;      //start t end of heap
     //Now sift up until curr's parent's key<curr's key
     while((curr!=0)&&(key(Heap,curr)>key(Heap,parent(curr))))
       {
         swap(Heap,curr,parent(curr));
         curr=parent(curr);
       }
      }
    public static HeapNode removemax()  //remove minimum value
      {
       Assert_notFalse(n>0,"Removing from empty heap ");
       swap(Heap,0,--n);//swap minimum with last value
       if(n!=0)     //Not on last intent
       siftdown(0); //Put new heap root val in corrent place 
       return Heap[n];
     }
  //Remove intent at specified position 
    public static HeapNode remove(int pos)
     {
      Assert_notFalse((pos>0)&&(pos<n),"illegal heap position ");
      swap(Heap,pos,--n);//swap with last value
      if(n!=0)     //Not on last intent
      siftdown(pos);//put new heap root val in corrent place
      return Heap[n];
     }
   public static void outMaxHeap()
     {
     for(int i=0;i<=n-1;i++)
     System.out.print(Heap[i].upperSize+"  ");
     System.out.println(); 
     }       

  static void heapsort()  //heapsort
    {
     System.out.println("建最大堆之后排序");
     
     for(int i=1;i<size-1;i++) //now sort
     System.out.print(removemax().upperSize+"  ");
     System.out.println( );    //removemax places min value at end of heap
    } 
 }// class MaxHeap
 
    class BBnode
    {
       BBnode  parent;
       boolean leftChild;
    
      BBnode(BBnode par,boolean ch)
         {
           parent=par;
           leftChild=ch;
         }
    }
    class HeapNode implements Comparable
      {
           BBnode liveNode;
           int upperSize;
           int cliqueSize;
           int level;
        HeapNode(BBnode node,int up,int size,int lev)
           {
             liveNode=node;
             upperSize=up;
             cliqueSize=size;
             level=lev;
           }
        public int compareTo(Object x)
         {
           int xup=((HeapNode)x).upperSize;
           if(upperSize<xup)return -1;
           if(upperSize==xup)return 0;
           return 1;
         }
      } 
    class BBClique 
      {
           static boolean [][]a;
           static MaxHeap heap;     
 
       private static void addLiveNode(int up,int size,int lev,BBnode par,boolean ch)
         {
           BBnode b=new BBnode(par,ch);
           HeapNode node=new HeapNode(b,up,size,lev);
           heap.insert(node);
         }

      public static int bbMaxClique(int [] bestx)
        {
          int n=bestx.length-1;
          HeapNode[] h=new HeapNode[n];
          MaxHeap heap=new MaxHeap(h,0,n);
          //
          BBnode enode=null;
          int i=1;
          int cn=0;
          int bestn=0;
          while(i!=n+1)
           {
            //
            boolean ok=true;
            BBnode bnode=enode;
            for(int j=i-1;j>0;bnode=bnode.parent,j--)
              if(bnode.leftChild && !a[i][j]) 
                {
                  ok=false;
                  break;
                }
              if(ok)
                {//
                  if(cn+1>bestn)bestn=cn+1;
                   addLiveNode(cn+n-i+1,cn+1,i+1,enode,true);
                }
              if(cn+n-i>=bestn)
                //
              addLiveNode(cn+n-i,cn,i+1,enode,false);
              HeapNode node=(HeapNode)heap.removemax();
              enode=node.liveNode;
              cn=node.cliqueSize;
              i=node.level;
          }
            //
          for(int j=n;j>0;j--)
            {
              bestx[j]=(enode.leftChild)?1:0;
              enode=enode.parent;
            }
          return  bestn;
      } 
    }       
   
  public class Fac6_6{
   
      public static void main(String args[])
  {
       BBClique abc=new BBClique();
     int n1=5; 
     int ak[]=new int[n1+1];
     boolean [][] aw=new boolean[n1+1][n1+1];
      aw[1][1]=false;aw[1][2]=true; aw[1][3]=false; aw[1][4]=true; aw[1][5]=true;
      aw[2][1]=true; aw[2][2]=false;aw[2][3]=true;  aw[2][4]=false;aw[2][5]=true;
      aw[3][1]=false;aw[3][2]=true; aw[3][3]=false; aw[3][4]=false;aw[3][5]=true;
      aw[4][1]=true; aw[4][2]=false;aw[4][3]=false; aw[4][4]=false;aw[4][5]=true;
      aw[5][1]=true; aw[5][2]=true; aw[5][3]=true;  aw[5][4]=true; aw[5][5]=false; 
     abc.a=aw;    
     System.out.println("最大團頂點數(shù)為 " + abc.bbMaxClique(ak));
     for(int i=1;i<=n1;i++)
     System.out.print("  "+ak[i]);
     System.out.println();
        
    
  }
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
青草av.久久免费一区| 成人精品视频一区| 亚洲自拍偷拍av| 国产精品麻豆久久久| 欧美成人福利视频| 国产精品美女久久福利网站| 波多野洁衣一区| 久久精品国产一区二区三| 亚洲国产日韩一区二区| 夜夜嗨av一区二区三区| 中文字幕亚洲精品在线观看| 国产日韩欧美一区二区三区综合| 日韩一级欧美一级| 欧洲色大大久久| 91浏览器打开| 91在线视频观看| 91国偷自产一区二区使用方法| 成人手机在线视频| 不卡的电视剧免费网站有什么| 国产精品一区二区男女羞羞无遮挡| 免费视频最近日韩| 精品无码三级在线观看视频| 久久激情五月激情| 精品亚洲porn| 国产一区不卡视频| 风流少妇一区二区| 99久久99精品久久久久久| 99久久99久久久精品齐齐| 国产乱理伦片在线观看夜一区 | 国产在线精品不卡| 韩国精品一区二区| 国产在线播放一区| 成人自拍视频在线观看| 高清在线不卡av| 99精品1区2区| 欧美日韩一区高清| 日韩欧美另类在线| 久久综合久久鬼色中文字| 国产日韩精品一区二区三区| 中文字幕一区二区三区乱码在线| 国产精品网站在线播放| 国产精品久久久久久久第一福利 | 久久日一线二线三线suv| 亚洲精品一区二区三区影院| 欧美岛国在线观看| 国产女同性恋一区二区| 亚洲麻豆国产自偷在线| 天堂精品中文字幕在线| 国产一区二三区| 99久久精品免费看国产| 欧美区一区二区三区| 在线综合视频播放| 久久精品欧美一区二区三区不卡| 最新日韩av在线| 亚洲成av人片观看| 国产米奇在线777精品观看| 91在线观看免费视频| 色播五月激情综合网| 日韩欧美在线不卡| 国产精品少妇自拍| 香蕉乱码成人久久天堂爱免费| 麻豆国产精品777777在线| 成人福利电影精品一区二区在线观看| 99久久伊人精品| 日韩欧美中文字幕一区| 亚洲欧美视频一区| 久久精品国产亚洲高清剧情介绍| 成人av资源下载| 欧美欧美欧美欧美首页| 中文字幕不卡在线| 午夜精品久久久久久久99水蜜桃 | 欧美色成人综合| 国产视频一区在线播放| 一区二区三区在线免费| 精品亚洲欧美一区| 欧美天堂亚洲电影院在线播放| 26uuu精品一区二区三区四区在线| 亚洲欧美另类在线| 国内成+人亚洲+欧美+综合在线| 91精品福利在线| 久久久www成人免费无遮挡大片| 亚洲综合在线五月| 国内一区二区在线| 欧美探花视频资源| 久久色在线视频| 午夜精品久久久久久久久久| 国产一区视频导航| 91精品欧美一区二区三区综合在 | 欧美亚一区二区| 久久综合九色综合欧美98| 亚洲图片欧美色图| 成人性视频免费网站| 欧美一区二区三区四区久久| 国产日产欧美一区| 国内精品伊人久久久久影院对白| 欧美亚洲日本国产| 亚洲人精品午夜| 不卡一区在线观看| 国产女主播在线一区二区| 精品在线播放免费| 在线成人免费视频| 亚洲自拍偷拍网站| 91亚洲资源网| 一区视频在线播放| 国产成人亚洲综合a∨婷婷| 日韩一级精品视频在线观看| 日韩有码一区二区三区| 欧美三级欧美一级| 亚洲自拍偷拍综合| 91国内精品野花午夜精品| 国产精品丝袜黑色高跟| 国产中文一区二区三区| 欧美一区二区黄| 亚洲成人免费看| 欧美日韩在线免费视频| 一区二区三区在线视频免费 | 国产无人区一区二区三区| 美脚の诱脚舐め脚责91| 91精品国产乱码| 日韩av一级片| 5566中文字幕一区二区电影 | 精品视频在线免费观看| 人人超碰91尤物精品国产| 2020国产精品自拍| 国产成人午夜精品5599| 亚洲人成7777| 538prom精品视频线放| 国产一区日韩二区欧美三区| 国产精品沙发午睡系列990531| 91在线国产观看| 亚洲成av人片一区二区| 精品sm在线观看| 成人久久18免费网站麻豆 | 在线视频中文字幕一区二区| 天天av天天翘天天综合网 | 国产精品影视在线观看| 国产精品国产馆在线真实露脸| 日本韩国精品在线| 日韩电影免费在线观看网站| 久久伊人蜜桃av一区二区| 97久久超碰国产精品| 亚洲1区2区3区4区| 国产情人综合久久777777| 色综合激情五月| 麻豆视频观看网址久久| 亚洲视频免费在线| 欧美一区二区日韩一区二区| 成人午夜在线播放| 亚洲成av人片| 国产精品亲子乱子伦xxxx裸| 欧美三级一区二区| 国产91丝袜在线播放| 午夜电影一区二区三区| 精品电影一区二区三区| 在线精品视频一区二区| 国产精品亚洲综合一区在线观看| 亚洲电影在线播放| 国产欧美一区二区在线观看| 欧美肥妇bbw| 99久久婷婷国产综合精品电影| 麻豆国产精品一区二区三区| 亚洲乱码国产乱码精品精的特点 | 亚洲第一激情av| 国产色综合久久| 69久久夜色精品国产69蝌蚪网| 不卡av在线免费观看| 狠狠色丁香婷婷综合| 亚洲成在线观看| 亚洲欧洲日韩综合一区二区| 精品欧美一区二区三区精品久久 | 7777女厕盗摄久久久| 91影院在线免费观看| 国产成人在线视频免费播放| 三级久久三级久久久| 一区二区三区精密机械公司| 国产欧美视频一区二区三区| 精品少妇一区二区三区日产乱码 | 久久久亚洲精华液精华液精华液| 精品视频在线免费看| 色综合色狠狠天天综合色| 国产宾馆实践打屁股91| 裸体一区二区三区| 亚洲444eee在线观看| 一级日本不卡的影视| 国产精品国产馆在线真实露脸| 久久久五月婷婷| 欧美α欧美αv大片| 日韩一卡二卡三卡四卡| 欧美亚洲国产一卡| 91在线视频官网| www.色精品| 成人91在线观看| 顶级嫩模精品视频在线看| 国产激情91久久精品导航| 国产一区二区三区免费看| 国产自产2019最新不卡| 国产露脸91国语对白| 国产九色sp调教91| 国产成人午夜精品5599| 丁香婷婷综合网|