青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

KISS(Keep It Simple, Standard)

  C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
  10 Posts :: 0 Stories :: 24 Comments :: 0 Trackbacks

常用鏈接

留言簿(10)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

2008年2月1日 #


這步還有句要說的就是:(在把OPEN表中最優(yōu)值的節(jié)點插入 CLOSE表中時如果在CLOSE表中已經存在那就要比較,如果存在的節(jié)點的權值比要插入的大,就要把存在的替換掉(節(jié)點中所有內容),否則就忽略).

第3步:就是重復第2步驟(示例圖如下)

我想因該明白了吧!










好了最后一張完工!

終點(12節(jié)點)找到了是吧!我想因該明白了吧!
posted @ 2008-02-01 17:09 QUIRE-0216 閱讀(1303) | 評論 (4)編輯 收藏

最近做了路徑搜索,看了網上的描述真是晦澀,所以自己就整理下!
圖畫的不太好, :)
綠色的是節(jié)點,紅色的為權值,箭頭為可通行的標志.

現(xiàn)在我們要從 0 節(jié)點 到 12 節(jié)點 找一條最優(yōu)路徑:
首先咱們要解決NODE點存貯的信息(結構):
struct NodeBaseInfo
{
   unsigned short nNodeID;   //番號
   unsigned long  nMeasure;            //權值
   NodeBaseInfo *pParent;            //父節(jié)點
};

我寫了簡單的結構大家可以根據(jù)自己需要定義(定義這個結構是為了更好理解)
下面講的是最主要的了:
DIJKSTAR算法中要定義兩個表:OPEN 和 CLOSE  (其實可以看作鏈表)
他的原理就是把沒有遍歷的點放在 OPEN 表中,把從 OPEN表中遍歷到的最短權值的點放入
CLOSE 表中,當插入 CLOSE表中的節(jié)點的番號于我們要的重點時算法結束;然后按照父節(jié)點(pParent)
向上遞歸就可以得到我們要的最優(yōu)路徑了。

第一步:應為 OPEN 和CLOSE表都是空的,把起點(0節(jié)點)插入CLOSE標中,它的權值為0。把起點(0節(jié)點)附近的節(jié)點(因該為可通行的)插入OPEN 表中(最好按權值從大道小的順序插入,這樣取得最優(yōu)值時,這樣速度就會很快)。(如示例圖)

第2步:從OPEN表中找到權值最小的節(jié)點,把它插入CLOSE 表中, 把這個節(jié)點的可連通的節(jié)點查入OPEN
表,(如果OPEN表中存在要查入的點,如果要插入的節(jié)點的權值比已經存在的小,就把已經查入的權值該為最小的,如果要插入的節(jié)點的權值比已經存在的大,就忽落它.)
(為了更好的理解我把父節(jié)點也加入了,如示例圖)

posted @ 2008-02-01 16:13 QUIRE-0216 閱讀(3922) | 評論 (12)編輯 收藏

2008年1月23日 #

本算法只采用移位、加減法、判斷和循環(huán)實現(xiàn),因為它不需要浮點運算,也不需要乘除運算,因此可以很方便地運用到各種芯片上去。

我們先來看看10進制下是如何手工計算開方的。
先看下面兩個算式,
x = 10*p + q  (1)
公式(1)左右平方之后得:
x^2 = 100*p^2 + 20pq + q^2 (2)
現(xiàn)在假設我們知道x^2和p,希望求出q來,求出了q也就求出了x^2的開方x了。
我們把公式(2)改寫為如下格式:
q = (x^2 - 100*p^2)/(20*p+q) (3)

這個算式左右都有q,因此無法直接計算出q來,因此手工的開方算法和手工除法算法一樣有一步需要猜值。

我們來一個手工計算的例子:計算1234567890的開方

首先我們把這個數(shù)兩位兩位一組分開,計算出最高位為3。也就是(3)中的p,最下面一行的334為余數(shù),也就是公式(3)中的(x^2 - 100*p^2)近似值
    3
  ---------------
 / 12 34 56 78 90
    9
  ---------------
 /  3 34

下面我們要找到一個0-9的數(shù)q使它最接近滿足公式(3)。我們先把p乘以20寫在334左邊:
                           3  q
                         ---------------
                        / 12 34 56 78 90
                           9
                         ---------------
(20*3+q)*q      /  3 34

我們看到q為5時(60+q)*q的值最接近334,而且不超過334。于是我們得到:
      3  5
    ---------------
   / 12 34 56 78 90
      9
    ---------------
65 /  3 34
      3 25
    ---------------
         9 56

接下來就是重復上面的步驟了,這里就不再啰嗦了。

這個手工算法其實和10進制關系不大,因此我們可以很容易的把它改為二進制,改為二進制之后,公式(3)就變成了:
q = (x^2 - 4*p^2)/(4*p+q) (4)

我們來看一個例子,計算100(二進制1100100)的開方:
       1  0  1  0
      -----------
     / 1 10 01 00
       1
      -----------
 100 / 0 10
       0 00
      -----------
1001 /   10 01
         10 01
      -----------
          0 00

這里每一步不再是把p乘以20了,而是把p乘以4,也就是把p右移兩位,而由于q的值只能為0或者1,所以我們只需要判斷余數(shù)(x^2 - 4*p^2)和(4*p+1)的大小關系,如果余數(shù)大于等于(4*p+q)那么該上一個1,否則該上一個0。

下面給出完成的C語言程序,其中root表示p,rem表示每步計算之后的余數(shù),divisor表示(4*p+1),通過a>>30取a的最高 2位,通過a<<=2將計算后的最高2位剔除。其中root的兩次<<1相當于4*p。程序完全是按照手工計算改寫的,應該不難理解。
unsigned short sqrt(unsigned long a){
  unsigned long rem = 0;
  unsigned long root = 0;
  unsigned long divisor = 0;
  for(int i=0; i<16; ++i){
    root <<= 1;
    rem = ((rem << 2) + (a >> 30));
    a <<= 2;
    divisor = (root<<1) + 1;
    if(divisor <= rem){
      rem -= divisor;
      root++;
    }
  }
  return (unsigned short)(root);
}

posted @ 2008-01-23 14:21 QUIRE-0216 閱讀(5293) | 評論 (1)編輯 收藏

2007年8月30日 #

void TransparentBlt(CDC *pDestDC, int nXDest, int nYDest, int nWidth, int nHeight, CBitmap * pBitmap, int nXsrc, int nYsrc, COLORREF clr)
{
 CDC maskDC, ImageDC;
 maskDC.CreateCompatibleDC(pDestDC);
 ImageDC.CreateCompatibleDC(pDestDC);

 CBitmap maskBMP;
 maskBMP.CreateBitmap(nWidth, nHeight, 1, 1, NULL);//創(chuàng)建單色掩碼位圖
 CBitmap *pOldBMP = ImageDC.SelectObject(pBitmap);
 CBitmap *maskOldBMP = maskDC.SelectObject(&maskBMP);
 
 ImageDC.SetBkColor(clr);// 設置透明色
 maskDC.BitBlt(0, 0, nWidth, nHeight, &ImageDC, nXsrc, nYsrc, SRCCOPY);

 //設置背景色為黑色,前景色為白色,將掩碼位圖與原位圖相"與"
 ImageDC.SetBkColor(RGB(0, 0, 0));
 ImageDC.SetTextColor(RGB(255, 255, 255));
 ImageDC.BitBlt(0, 0, nWidth, nHeight, &maskDC, nXsrc, nYsrc, SRCAND);

 //設置背景色為白色,前景色為黑色,將掩碼位圖與背景進行“與”運算
 pDestDC->SetBkColor(RGB(255, 255, 255));
 pDestDC->SetTextColor(RGB(0, 0, 0));
 pDestDC->BitBlt(nXDest, nYDest, nWidth, nHeight, &maskDC, nXsrc, nYsrc, SRCAND);
 // "或"運算,生成最終效果
 pDestDC->BitBlt(nXDest, nYDest, nWidth, nHeight, &ImageDC, nXsrc, nYsrc, SRCPAINT);

 if (pOldBMP) ImageDC.SelectObject(pOldBMP);
 ImageDC.DeleteDC();
 if (maskOldBMP) maskDC.SelectObject(maskOldBMP);
 maskDC.DeleteDC();
 if (maskBMP.m_hObject) maskBMP.DeleteObject();
}

我就不怎么解釋了!如不理解,請看我轉的(透明位圖的顯示中的(二、實現(xiàn)TransparentBlt函數(shù))的原理),其他部分都就什么必要了!呵呵!
posted @ 2007-08-30 17:05 QUIRE-0216 閱讀(562) | 評論 (2)編輯 收藏

包含透明色的位圖的繪制方法有多種,最簡單的方法是調用現(xiàn)成的函數(shù):TransparentBlt,也可以通過自己的代碼實現(xiàn)類似 TransparentBlt的功能,實現(xiàn)過程也有兩種形式,一種是事先做一張掩碼位圖,另一種是動態(tài)生成掩碼位圖。本文將介紹動態(tài)生成掩碼位圖繪制具有透明區(qū)域位圖的方法。

一、TransparentBlt 函數(shù)的使用

TransparentBlt 函數(shù)在Windows98/Windows2000以上版本運行,系統(tǒng)中需要包含 Msimg32.dll,使用時可以鏈接 Msimg32.lib。
Windows98下的TransparentBlt會產生資源泄漏,所以不建議在WIN98下使用該函數(shù)。
TransparentBlt函數(shù)原型如下:

BOOL TransparentBlt(
HDC hdcDest,      // 目標DC
int nXOriginDest,   // 目標X偏移
int nYOriginDest,   // 目標Y偏移
int nWidthDest,     // 目標寬度
int hHeightDest,    // 目標高度
HDC hdcSrc,         // 源DC
int nXOriginSrc,    // 源X起點
int nYOriginSrc,    // 源Y起點
int nWidthSrc,      // 源寬度
int nHeightSrc,     // 源高度
UINT crTransparent  // 透明色,COLORREF類型
);
使用示例:
CBitmap FootballBMP;
FootballBMP.LoadBitmap(IDB_FOOTBALLBMP);
CDC ImageDC;
ImageDC.CreateCompatibleDC(pDC);
CBitmap *pOldImageBMP = ImageDC.SelectObject(&FootballBMP);
TransparentBlt(pDC->m_hDC, 0, 0, 218, 199, ImageDC.m_hDC, 0, 0, 218, 199, RGB(0,0,0xff));
ImageDC.SelectObject(pOldImageBMP);
二、實現(xiàn)TransparentBlt函數(shù)

為了理解具有透明色位圖的繪制過程,我們來親手建立一個具有同TransparentBlt功能一致的實驗函數(shù),稱之為TransparentBlt2。

實驗素材:有兩張位圖:bk.bmp是背景位圖,football.bmp包含透明區(qū)域,透明色為藍色RGB(0,0,0xff)
實驗目的:以bk.bmp為背景,將football.bmp繪制到背景中,形成如下的最終效果圖。

 



2.1 透明位圖繪制原理
假設football.bmp ->載入 HBITMAP hImageBMP -> 選入 HDC hImageDC

2.1.1 生成足球的單色掩碼位圖,透明區(qū)域為白色(全1),非透明區(qū)域為黑色(全0)
HBITMAP hMaskBMP = CreateBitmap(nWidthDest, nHeightDest, 1, 1, NULL); // 建立單色位圖
SetBkColor(hImageDC, RGB(0,0,0xff)); // 設置背景色為藍色
BitBlt(hMaskDC, 0, 0, nWidthDest, nHeightDest, hImageDC, 0, 0, SRCCOPY); // 拷貝到hMaskDC
這樣足球位圖中藍色區(qū)域在掩碼位圖中成了白色,其它區(qū)域為黑色,此時hMaskBMP 如下圖:
(圖一)

2.1.2 設置背景色為黑色,前景色為白色,將掩碼位圖(圖一)與足球位圖相"與"
SetBkColor(hImageDC, RGB(0,0,0));
SetTextColor(hImageDC, RGB(255,255,255));
BitBlt(hImageDC, 0, 0, nWidthDest, nHeightDest, hMaskDC, 0, 0, SRCAND);
這樣,掩碼位圖中背景色(黑色)的區(qū)域在hImageBMP中被保留,前景色(白色)的部分變?yōu)楹谏?此時hImageBMP 如下圖:
(圖二)

2.1.3 設置背景色為白色,前景色為黑色,將掩碼位圖(圖一)與背景進行“與”運算
SetBkColor(hdcDest,RGB(255,255,255));
SetTextColor(hdcDest,RGB(0,0,0));
BitBlt(hdcDest, nXOriginDest, nYOriginDest, nWidthDest, nHeightDest, hMaskDC, 0, 0, SRCAND);
掩碼中白色區(qū)域(數(shù)據(jù)與1相“與”結果不變)使背景保持不變,黑色區(qū)域變成黑色,此時背景顯示如下:
(圖三)

2.1.4 將hImageBMP(圖二)與背景(圖三)進行“或”運算
BitBlt(hdcDest, nXOriginDest, nYOriginDest, nWidthDest, nHeightDest, hImageDC, 0, 0, SRCPAINT);
這樣就將足球繪制到背景上了。

2.2 TransparentBlt2函數(shù)全部實現(xiàn)代碼
void TransparentBlt2( HDC hdcDest,      // 目標DC
int nXOriginDest,   // 目標X偏移
int nYOriginDest,   // 目標Y偏移
int nWidthDest,     // 目標寬度
int nHeightDest,    // 目標高度
HDC hdcSrc,         // 源DC
int nXOriginSrc,    // 源X起點
int nYOriginSrc,    // 源Y起點
int nWidthSrc,      // 源寬度
int nHeightSrc,     // 源高度
UINT crTransparent  // 透明色,COLORREF類型
)
{
HBITMAP hOldImageBMP, hImageBMP = CreateCompatibleBitmap(hdcDest, nWidthDest, nHeightDest);	// 創(chuàng)建兼容位圖
HBITMAP hOldMaskBMP, hMaskBMP = CreateBitmap(nWidthDest, nHeightDest, 1, 1, NULL);			// 創(chuàng)建單色掩碼位圖
HDC		hImageDC = CreateCompatibleDC(hdcDest);
HDC		hMaskDC = CreateCompatibleDC(hdcDest);
hOldImageBMP = (HBITMAP)SelectObject(hImageDC, hImageBMP);
hOldMaskBMP = (HBITMAP)SelectObject(hMaskDC, hMaskBMP);
// 將源DC中的位圖拷貝到臨時DC中
if (nWidthDest == nWidthSrc && nHeightDest == nHeightSrc)
BitBlt(hImageDC, 0, 0, nWidthDest, nHeightDest, hdcSrc, nXOriginSrc, nYOriginSrc, SRCCOPY);
else
StretchBlt(hImageDC, 0, 0, nWidthDest, nHeightDest,
hdcSrc, nXOriginSrc, nYOriginSrc, nWidthSrc, nHeightSrc, SRCCOPY);
// 設置透明色
SetBkColor(hImageDC, crTransparent);
// 生成透明區(qū)域為白色,其它區(qū)域為黑色的掩碼位圖
BitBlt(hMaskDC, 0, 0, nWidthDest, nHeightDest, hImageDC, 0, 0, SRCCOPY);
// 生成透明區(qū)域為黑色,其它區(qū)域保持不變的位圖
SetBkColor(hImageDC, RGB(0,0,0));
SetTextColor(hImageDC, RGB(255,255,255));
BitBlt(hImageDC, 0, 0, nWidthDest, nHeightDest, hMaskDC, 0, 0, SRCAND);
// 透明部分保持屏幕不變,其它部分變成黑色
SetBkColor(hdcDest,RGB(255,255,255));
SetTextColor(hdcDest,RGB(0,0,0));
BitBlt(hdcDest, nXOriginDest, nYOriginDest, nWidthDest, nHeightDest, hMaskDC, 0, 0, SRCAND);
// "或"運算,生成最終效果
BitBlt(hdcDest, nXOriginDest, nYOriginDest, nWidthDest, nHeightDest, hImageDC, 0, 0, SRCPAINT);
// 清理、恢復
SelectObject(hImageDC, hOldImageBMP);
DeleteDC(hImageDC);
SelectObject(hMaskDC, hOldMaskBMP);
DeleteDC(hMaskDC);
DeleteObject(hImageBMP);
DeleteObject(hMaskBMP);
}
2.3 TransparentBlt的另外一個版本:TransparentBltU

TransparentBltU是Christian Graus 在WinDEV發(fā)表的一個函數(shù),功能與TransparentBlt一致,以下是全部實現(xiàn)代碼:
bool TransparentBltU(
HDC dcDest,         // handle to Dest DC
int nXOriginDest,   // x-coord of destination upper-left corner
int nYOriginDest,   // y-coord of destination upper-left corner
int nWidthDest,     // width of destination rectangle
int nHeightDest,    // height of destination rectangle
HDC dcSrc,          // handle to source DC
int nXOriginSrc,    // x-coord of source upper-left corner
int nYOriginSrc,    // y-coord of source upper-left corner
int nWidthSrc,      // width of source rectangle
int nHeightSrc,     // height of source rectangle
UINT crTransparent  // color to make transparent
)
{
if (nWidthDest < 1) return false;
if (nWidthSrc < 1) return false;
if (nHeightDest < 1) return false;
if (nHeightSrc < 1) return false;
HDC dc = CreateCompatibleDC(NULL);
HBITMAP bitmap = CreateBitmap(nWidthSrc, nHeightSrc, 1, GetDeviceCaps(dc,
BITSPIXEL), NULL);
if (bitmap == NULL)
{
DeleteDC(dc);
return false;
}
HBITMAP oldBitmap = (HBITMAP)SelectObject(dc, bitmap);
if (!BitBlt(dc, 0, 0, nWidthSrc, nHeightSrc, dcSrc, nXOriginSrc,
nYOriginSrc, SRCCOPY))
{
SelectObject(dc, oldBitmap);
DeleteObject(bitmap);
DeleteDC(dc);
return false;
}
HDC maskDC = CreateCompatibleDC(NULL);
HBITMAP maskBitmap = CreateBitmap(nWidthSrc, nHeightSrc, 1, 1, NULL);
if (maskBitmap == NULL)
{
SelectObject(dc, oldBitmap);
DeleteObject(bitmap);
DeleteDC(dc);
DeleteDC(maskDC);
return false;
}
HBITMAP oldMask =  (HBITMAP)SelectObject(maskDC, maskBitmap);
SetBkColor(maskDC, RGB(0,0,0));
SetTextColor(maskDC, RGB(255,255,255));
if (!BitBlt(maskDC, 0,0,nWidthSrc,nHeightSrc,NULL,0,0,BLACKNESS))
{
SelectObject(maskDC, oldMask);
DeleteObject(maskBitmap);
DeleteDC(maskDC);
SelectObject(dc, oldBitmap);
DeleteObject(bitmap);
DeleteDC(dc);
return false;
}
SetBkColor(dc, crTransparent);
BitBlt(maskDC, 0,0,nWidthSrc,nHeightSrc,dc,0,0,SRCINVERT);
SetBkColor(dc, RGB(0,0,0));
SetTextColor(dc, RGB(255,255,255));
BitBlt(dc, 0,0,nWidthSrc,nHeightSrc,maskDC,0,0,SRCAND);
HDC newMaskDC = CreateCompatibleDC(NULL);
HBITMAP newMask;
newMask = CreateBitmap(nWidthDest, nHeightDest, 1,
GetDeviceCaps(newMaskDC, BITSPIXEL), NULL);
if (newMask == NULL)
{
SelectObject(dc, oldBitmap);
DeleteDC(dc);
SelectObject(maskDC, oldMask);
DeleteDC(maskDC);
DeleteDC(newMaskDC);
DeleteObject(bitmap);
DeleteObject(maskBitmap);
return false;
}
SetStretchBltMode(newMaskDC, COLORONCOLOR);
HBITMAP oldNewMask = (HBITMAP) SelectObject(newMaskDC, newMask);
StretchBlt(newMaskDC, 0, 0, nWidthDest, nHeightDest, maskDC, 0, 0,
nWidthSrc, nHeightSrc, SRCCOPY);
SelectObject(maskDC, oldMask);
DeleteDC(maskDC);
DeleteObject(maskBitmap);
HDC newImageDC = CreateCompatibleDC(NULL);
HBITMAP newImage = CreateBitmap(nWidthDest, nHeightDest, 1,
GetDeviceCaps(newMaskDC, BITSPIXEL), NULL);
if (newImage == NULL)
{
SelectObject(dc, oldBitmap);
DeleteDC(dc);
DeleteDC(newMaskDC);
DeleteObject(bitmap);
return false;
}
HBITMAP oldNewImage = (HBITMAP)SelectObject(newImageDC, newImage);
StretchBlt(newImageDC, 0, 0, nWidthDest, nHeightDest, dc, 0, 0, nWidthSrc,
nHeightSrc, SRCCOPY);
SelectObject(dc, oldBitmap);
DeleteDC(dc);
DeleteObject(bitmap);
BitBlt( dcDest, nXOriginDest, nYOriginDest, nWidthDest, nHeightDest,
newMaskDC, 0, 0, SRCAND);
BitBlt( dcDest, nXOriginDest, nYOriginDest, nWidthDest, nHeightDest,
newImageDC, 0, 0, SRCPAINT);
SelectObject(newImageDC, oldNewImage);
DeleteDC(newImageDC);
SelectObject(newMaskDC, oldNewMask);
DeleteDC(newMaskDC);
DeleteObject(newImage);
DeleteObject(newMask);
return true;
}

說明:本文提供的TransparentBlt2函數(shù)旨在說明透明位圖的顯示原理,在Windows2000以上環(huán)境實際運用中建議使用現(xiàn)成的TransparentBlt函數(shù)來繪制透明位圖。
posted @ 2007-08-30 16:52 QUIRE-0216 閱讀(937) | 評論 (1)編輯 收藏

2007年8月24日 #

#ifndef _DOUBLE_H_
#define _DOUBLE_H_

template<class T>
class Double;

template<class T>
class DoubleNode
{
 friend class Double<T>;
private:
 T data;
 DoubleNode<T> *pre;
 DoubleNode<T> *next;
};

template<class T>
class Double
{
 public:
  Double();//{head=end=NULL;}
  ~Double();
  void Erase();
  void reverse();
  int GetLength()const;
  bool IsEmpty()const;
  bool Find(int k, T& x)const;
  int Search(T& x)const;
  Double<T>& Delete(int k, T& x);
  Double<T>& Insert(int k, const T& x);
  void output(ostream& out)const;
  friend ostream& operator << (ostream& out, const Double<T>& x);
 private:
  DoubleNode<T> *head;
  DoubleNode<T> *end;
  int length;
};

template<class T>
Double<T>::Double()
{
 head = new DoubleNode<T>;
 end = new DoubleNode<T>;
 head->pre = NULL;
 head->next = end;
 end->pre = head;
 end->next = NULL;

 length = 0;
}

template<class T>
Double<T>::~Double()
{
 Erase();
}

template<class T>
void Double<T>::Erase()
{
 DoubleNode<T> *current = head;
 while (current)
 {
  head = head->next;
  delete current;
  current = head;
 }
 length = 0;
}

template<class T>
int Double<T>::GetLength()const
{
 return length;
}

template<class T>
bool Double<T>::IsEmpty()const
{
 return length == 0;
}

template<class T>
bool Double<T>::Find(int k, T& x)const
{

 if (length == 0)
 {
  throw exception("DoubleNode is empty!");
 }
 else if(k<1 || k>length)
 {
  throw exception("no find the position of k");
 }

 DoubleNode<T> *current = head->next;
 for (int i=1; (i<k)&&current; ++i)
 {
  current = current->next;
 }

 if (current)
 {
  x = current->data;
  return true;
 }

 return false;
}


template<class T>
int Double<T>::Search(T& x)const
{
 int nIndex = 1;
 DoubleNode<T> *current = head->next;
 while (current && current->data != x)
 {
  ++nIndex;
  current = current->next;
 }

 if (current)
 {
  return nIndex;
 }

 return -1;
}

template<class T>
Double<T>& Double<T>::Delete(int k, T& x)
{
 if (length == 0)
 {
  throw exception("DoubleNode is empty!");
 }
 else if(k<1 || k>length)
 {
  throw exception("no find the position of k, so can't delete!");
 }

 DoubleNode<T> *current = head->next; 
 for (int i=1; (i<k)&&current; ++i)
 {
  current = current->next;
 }

 DoubleNode<T> * p = current;
 current->pre->next = current->next;
 current->next->pre = current->pre;

 x = p->data;
 delete p;
 p = NULL;
 --length;

 return *this;
}


template<class T>
Double<T>& Double<T>::Insert(int k, const T& x)
{
 if (k>=0 && k<= length)
 {
  DoubleNode<T> *newNode = new DoubleNode<T>;
  newNode->data = x;

  DoubleNode<T> *current = head;
  for (int i=0; i<k; ++i)
  {
   current = current->next;
  }

  newNode->pre = current;
  newNode->next = current->next;
  current->next->pre = newNode;
  current->next = newNode;
  
  
  ++length;
 }
 else
 {
  throw exception("no find the position of k, so can't insert!");
 }

 return *this;
}

template<class T>
void Double<T>::output(ostream& out)const
{
 DoubleNode<T> *current = head->next;
 while (current!=end)
 {
  out << current->data << " ";
  current = current->next;
 }
}

template<class T>
ostream& operator<< (ostream& out, const Double<T>& x)
{
 x.output(out);
 return out;
}

template<class T>
void Double<T>::reverse()
{
 DoubleNode<T> *p1 = head;
 DoubleNode<T> *p2 = NULL;
 DoubleNode<T> *pNode;

 while (p1 != NULL)
 {
  pNode = p1;
  pNode->pre = p1->next;
  p1 = p1->next;
  pNode->next = p2;
  p2 = pNode;
 }

 end = head;
 head = p2;
}

#endif

以上為雙鏈表的基本操作,代碼已經測試過了,可以直接用!
其中,head. end在構造函數(shù)時,New了兩個對象,是為了Insert 和 Delete操作的方便!
更好的方式是:把指針和數(shù)據(jù)分開,這樣head,end就可以節(jié)省存貯空間了!
方式如下:
//指針數(shù)據(jù)部分(后續(xù)指針和前驅指針)
struct Node_base
{
 Node_base *next;
 Node_base *pre;
};

//添加實際數(shù)據(jù)部分
template <class T>
struct Node : public Node_base
{
 T m_data;
};

posted @ 2007-08-24 17:06 QUIRE-0216 閱讀(1416) | 評論 (4)編輯 收藏

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美一区二区三区久久精品| 国产日韩欧美亚洲| 欧美一区二区久久久| 在线综合亚洲| 亚洲嫩草精品久久| 欧美在线日韩| 久久青草久久| 欧美 日韩 国产 一区| 欧美大成色www永久网站婷| 久久综合久久综合久久| 欧美黄色免费网站| 国产精品一区二区在线观看不卡 | 午夜亚洲福利在线老司机| 亚洲淫片在线视频| 久久精品日韩一区二区三区| 久久艳片www.17c.com| 欧美激情第10页| 国产精品亚发布| 亚洲国产美女久久久久| 亚洲自拍16p| 欧美高清在线一区二区| 亚洲天堂男人| 欧美电影免费| 国产在线拍偷自揄拍精品| 日韩亚洲综合在线| 久久综合久久久| 亚洲午夜高清视频| 欧美高清在线播放| 极品尤物av久久免费看| 亚洲综合首页| 91久久精品国产91久久性色tv | 久久福利精品| 欧美色播在线播放| 在线欧美视频| 欧美在线观看天堂一区二区三区| 欧美xxx在线观看| 亚洲欧美日本精品| 欧美日韩卡一卡二| 亚洲日本aⅴ片在线观看香蕉| 午夜精品久久久久久久白皮肤| 亚洲福利国产| 久久久久久久久久久久久久一区| 国产精品成av人在线视午夜片| 亚洲国产日韩美| 久久一区亚洲| 欧美一区二区国产| 亚洲素人一区二区| 欧美激情1区2区3区| 国内精品美女av在线播放| 亚洲一区二区精品| 亚洲三级毛片| 欧美精品自拍| 亚洲精品乱码久久久久久日本蜜臀 | 韩国女主播一区| 久久国产精品一区二区三区四区 | 精品91视频| 久久久久久久久伊人| 亚洲主播在线播放| 国产麻豆综合| 久久精品在线| 久久久五月天| 91久久极品少妇xxxxⅹ软件| 欧美ed2k| 欧美激情精品久久久久久免费印度| 在线观看欧美激情| 欧美成人dvd在线视频| 久久躁日日躁aaaaxxxx| 在线免费观看一区二区三区| 免费在线欧美黄色| 欧美激情在线| 亚洲免费在线| 久久疯狂做爰流白浆xx| 激情婷婷欧美| 亚洲韩国青草视频| 欧美日韩系列| 久久aⅴ国产紧身牛仔裤| 久久大综合网| 亚洲精品护士| 中文在线一区| 国产午夜精品久久久| 美女主播一区| 欧美日韩精品免费看| 欧美在线免费播放| 免费不卡在线观看av| 一区二区三区视频在线观看| 中文一区字幕| 亚洲电影在线播放| 一区二区成人精品 | 韩国三级在线一区| 亚洲高清资源| 国产嫩草一区二区三区在线观看| 久久九九精品| 欧美日本三区| 久久久噜噜噜久久| 欧美日韩国产一中文字不卡| 欧美一区二区三区四区高清| 久久乐国产精品| 亚洲综合99| 欧美日本国产精品| 国内精品久久久久影院 日本资源| 欧美一区二区三区视频| 久久久蜜桃一区二区人| 亚洲最新视频在线播放| 午夜精品短视频| 亚洲免费观看高清完整版在线观看熊 | 中文日韩电影网站| 亚洲国产欧美一区二区三区久久 | 国产精品一区久久| 男人插女人欧美| 国产精品视频| 亚洲美女性视频| 亚洲成人资源网| 亚洲视频电影在线| 亚洲精品午夜| 久久网站热最新地址| 午夜在线电影亚洲一区| 欧美电影免费观看| 久久综合电影| 国产视频久久久久久久| 亚洲久久一区| 亚洲人在线视频| 久热精品在线| 卡一卡二国产精品| 欧美亚洲综合久久| 黄网站色欧美视频| 亚洲午夜av电影| 亚洲免费成人av电影| 欧美在线黄色| 欧美在线视频日韩| 国产精品欧美日韩一区| 夜夜狂射影院欧美极品| 亚洲精品孕妇| 欧美精品粉嫩高潮一区二区 | 在线观看一区二区视频| 午夜精品久久久久久久白皮肤| 亚洲一区二区三区视频| 欧美日韩精品一区二区三区四区| 亚洲国产精品999| 亚洲国产另类精品专区| 免费日韩视频| 亚洲一区二区三区四区在线观看| 亚洲伊人网站| 亚洲午夜久久久| 欧美伦理影院| 亚洲高清免费在线| 亚洲精品偷拍| 欧美高清在线播放| 亚洲精品孕妇| 亚洲综合第一| 国产一区视频网站| 久久视频在线免费观看| 欧美xart系列高清| 日韩视频精品在线观看| 欧美日韩综合视频| 亚洲欧美在线高清| 榴莲视频成人在线观看| 亚洲国产精品123| 欧美日韩国产综合视频在线| 一本大道av伊人久久综合| 中文在线一区| 国产欧美精品xxxx另类| 在线观看欧美| 午夜精品久久久久久久| 亚洲欧美一区二区三区极速播放| 国产精品福利久久久| 亚洲影院污污.| 另类欧美日韩国产在线| 亚洲精选在线观看| 国产乱理伦片在线观看夜一区| 性色av一区二区三区在线观看| 久久综合伊人77777蜜臀| 99热精品在线观看| 国产日产欧美a一级在线| 久久夜色精品国产| 一本久久精品一区二区| 久久精品亚洲乱码伦伦中文| 亚洲高清视频一区二区| 欧美图区在线视频| 毛片av中文字幕一区二区| 亚洲视频1区2区| 欧美激情欧美激情在线五月| 亚洲欧美日韩久久精品| 亚洲国产精品一区二区www在线 | 欧美一级二级三级蜜桃| 欧美成人亚洲| 久久精品国产精品亚洲综合| 91久久精品视频| 国产亚洲欧美激情| 欧美日韩高清在线播放| 久久综合久久美利坚合众国| 亚洲综合二区| 99re8这里有精品热视频免费| 久久亚洲私人国产精品va媚药| 一区二区久久| 亚洲日本中文字幕免费在线不卡| 国产女主播一区二区三区| 欧美日韩视频第一区| 欧美本精品男人aⅴ天堂| 久久精品最新地址| 午夜在线电影亚洲一区|