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

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

?? lsmatrix.h

?? 這是一本數據結構與算法書中所有算法的源代碼,內容非常豐富,值得一看.
?? H
字號:
// header file lsmatrix.h
// linked representation of a sparse matrix

#ifndef LinkedMatrix_
#define LinkedMatrix_

#include <stdlib.h>
#include <iostream.h>
#include "echain.h"
#include "citer.h"
#include "matnodes.h"
#include "xcept.h"

template<class T>
class LinkedMatrix {
   friend ostream& operator<<
          (ostream&, const LinkedMatrix<T>&);
   friend istream& operator>>
          (istream&, LinkedMatrix<T>&);
   public:
      LinkedMatrix(){}
      ~LinkedMatrix(){}
      void Transpose(LinkedMatrix<T> &b) const;
   private:
      int rows, cols;        // matrix dimensions
      Chain<HeadNode<T> > a; // head node chain
};

template<class T>
istream& operator>>(istream& in, LinkedMatrix<T>& x)
{// Input matrix x from the stream in.
   x.a.Erase(); // delete all nodes from x

   // get matrix characteristics
   int terms;   // number of terms to be input
   cout << "Enter number of rows, columns, and terms" 
        << endl;
   in >> x.rows >> x.cols >> terms;

   // create fictional row zero
   HeadNode<T> H;  // head node for current row
   H.row = 0;      // current row number

   // get terms of matrix x
   for (int i = 1; i <= terms; i++) {
      // get next term
      cout << "Enter row, column, and value of term " 
           << i << endl;
      int row, col;
      T value;
      in >> row >> col >> value;

      // check if new term is part of current row
      if (row > H.row) {// start a new row
         // append head node H of current row to
         // head node chain x.a only if row not zero
         if (H.row) x.a.Append(H);

         // prepare H for new row
         H.row = row;
         H.a.Zero();}  // save from chain destructor

      // add new term to row chain
      CNode<T> *c = new CNode<T>;
      c->col = col;
      c->value = value;
      H.a.Append(*c);
      }

   // take care of last row of matrix
   if (H.row) x.a.Append(H);
   H.a.Zero(); // save from chain destructor

   return in;
}

template<class T>
ostream& operator<<(ostream& out,
                    const LinkedMatrix<T>& x)
{// Put matrix x into the output stream out.
   ChainIterator<HeadNode<T> > p;// head node iterator

   // output matrix dimensions
   out << "rows = " << x.rows << " columns = "
       << x.cols << endl;

   // set h to point to first head node
   HeadNode<T> *h = p.Initialize(x.a);
   if (!h) {out << "No non-zero terms" << endl;
   	    return out;}

   // output one row at a time
   while (h) {
      out << "row " << h->row << endl;
      out << h->a << endl;  // output row chain
      h = p.Next();         // next head node
      }

   return out;
}

template<class T>
void LinkedMatrix<T>::
     Transpose(LinkedMatrix<T> &b) const
{// Return transpose of *this as matrix b.
   b.a.Erase(); // delete all nodes from b

   // create bins to collect rows of b
   Chain<CNode<T> > *bin;
   bin = new Chain<CNode<T> > [cols + 1];

   // head node iterator
   ChainIterator<HeadNode<T> > p;

   // set h to point to first head node of *this
   HeadNode<T> *h = p.Initialize(a);

   // copy terms of *this into bins
   while (h) { // examine all rows
      int r = h->row; // row number for row chain

      // row chain iterator
      ChainIterator<CNode<T> > q;

      // set z to point to first node in row chain
      CNode<T> *z = q.Initialize(h->a);

      CNode<T> x;  // temporary node
      // terms from row r of *this go to column r of b
      x.col = r;

      // examine all terms in row r of *this
      while (z) {// go down row r
         x.value = z->value;
         // append term to bin for row z->col of b
         bin[z->col].Append(x);
         z = q.Next();  // next term in row
         }

      h = p.Next(); // go to next row
      }

   // set dimensions of b
   b.rows = cols;
   b.cols = rows;

   // assemble head node chain of b
   HeadNode<T> H;
   // scan bins
   for (int i = 1; i <= cols; i++)
      if (!bin[i].IsEmpty()) {// row i of transpose
         H.row = i;
         H.a = bin[i];
         b.a.Append(H);
         bin[i].Zero();} // save from destructor

   H.a.Zero(); // save from destructor

   delete [] bin;
}

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久久久岛一牛影视 | 国产三级欧美三级| 欧美国产精品久久| 亚洲影院久久精品| 黄色资源网久久资源365| 在线观看视频一区| 久久精品在这里| 日韩国产精品久久久久久亚洲| 97se亚洲国产综合自在线观| 精品卡一卡二卡三卡四在线| 亚洲午夜免费电影| 色哟哟精品一区| 国产欧美一区二区三区在线看蜜臀| 亚洲国产裸拍裸体视频在线观看乱了 | 欧美日韩在线精品一区二区三区激情| 欧美大片拔萝卜| 亚洲国产精品一区二区尤物区| 国产91色综合久久免费分享| 91精品国产91久久久久久一区二区| 亚洲视频1区2区| 国产精品一卡二卡| 精品国内片67194| 午夜精品免费在线观看| 色综合久久中文字幕| 国产精品无人区| 国产麻豆视频一区| 久久综合99re88久久爱| 日韩av不卡在线观看| 欧美日韩一级大片网址| 一个色在线综合| 欧美在线免费观看亚洲| 一区二区三区精品视频在线| 色综合久久综合中文综合网| 国产精品九色蝌蚪自拍| 国产99久久久国产精品潘金网站| 日韩美女一区二区三区四区| 日本美女一区二区| 欧美一级高清片在线观看| 日本不卡在线视频| 欧美一区午夜精品| 免费看欧美女人艹b| 日韩一卡二卡三卡| 久久爱另类一区二区小说| 精品人在线二区三区| 国产精品一区二区黑丝| 国产欧美va欧美不卡在线| 国产成人午夜视频| 国产精品久久一卡二卡| 99精品一区二区三区| 亚洲欧美电影院| 欧美三级日韩在线| 免费黄网站欧美| 久久久久久亚洲综合影院红桃 | 三级在线观看一区二区| 91精品国产色综合久久不卡电影 | 综合久久一区二区三区| 色诱亚洲精品久久久久久| 亚洲成在线观看| 精品国产乱码久久久久久老虎| 激情深爱一区二区| **欧美大码日韩| 精品视频1区2区3区| 久久99精品国产麻豆婷婷| 国产精品国产自产拍高清av | 日韩视频中午一区| 国产成人一区在线| 亚洲成人7777| 欧美精品一区二区不卡 | 555夜色666亚洲国产免| 国产精品自拍av| 亚洲一二三专区| 久久在线观看免费| 色噜噜狠狠成人中文综合| 老司机午夜精品| 亚洲精品亚洲人成人网在线播放| 日韩欧美中文字幕制服| 99精品久久免费看蜜臀剧情介绍| 人妖欧美一区二区| 综合激情网...| 久久日一线二线三线suv| 91精品91久久久中77777| 国产一区91精品张津瑜| 亚洲一区二区视频在线观看| 国产偷国产偷精品高清尤物| 欧美日韩国产免费一区二区| 成人一区二区在线观看| 麻豆91免费看| 亚洲一二三专区| 亚洲日本va在线观看| 久久免费电影网| 91精品国产一区二区三区| 91福利视频久久久久| 国产成人在线网站| 久久精品国产99| 午夜精品久久久久久久蜜桃app| 亚洲国产高清在线| 久久亚洲欧美国产精品乐播| 欧美另类久久久品| 在线一区二区三区四区| 99免费精品视频| 国产成人综合在线播放| 久久国产精品99久久久久久老狼 | 激情图区综合网| 人妖欧美一区二区| 五月激情综合色| 亚洲综合免费观看高清完整版在线 | 99久久综合国产精品| 国产精品一区二区免费不卡| 蜜桃视频一区二区三区| 亚洲不卡在线观看| 亚洲一区二区三区四区的| 亚洲天堂2016| 亚洲欧美韩国综合色| 亚洲激情成人在线| 一区二区三区加勒比av| 亚洲精品老司机| 亚洲精品免费播放| 亚洲在线观看免费| 亚洲va韩国va欧美va| 亚洲超碰精品一区二区| 婷婷丁香久久五月婷婷| 五月天网站亚洲| 日本欧美加勒比视频| 日本视频中文字幕一区二区三区| 午夜激情久久久| 免费观看一级特黄欧美大片| 日韩vs国产vs欧美| 九九九久久久精品| 粉嫩av亚洲一区二区图片| 粉嫩av一区二区三区在线播放| 成人av小说网| 欧美色图一区二区三区| 欧美一区二区三区免费大片| 日韩欧美久久一区| 国产婷婷一区二区| 亚洲色图欧美在线| 亚洲一区二区三区四区在线免费观看 | 国产一二精品视频| 成人激情电影免费在线观看| 99久久国产综合精品麻豆| 欧美综合视频在线观看| 91精品久久久久久蜜臀| 久久影院视频免费| 国产清纯白嫩初高生在线观看91 | 精品蜜桃在线看| 亚洲国产精品精华液2区45| 亚洲日本va午夜在线影院| 午夜激情一区二区| 国产高清久久久久| av动漫一区二区| 欧美日韩欧美一区二区| 久久综合久久综合亚洲| 亚洲男人都懂的| 麻豆精品一区二区三区| 成人av在线一区二区| 在线播放中文字幕一区| 久久精品视频免费| 亚洲一区影音先锋| 精品一区二区三区在线观看| 97久久精品人人澡人人爽| 91精品啪在线观看国产60岁| 国产精品美女久久久久久久久 | 中文字幕一区二区三区在线不卡| 亚洲国产欧美在线| 国产成人午夜精品影院观看视频 | 春色校园综合激情亚洲| 欧美日韩在线电影| 国产精品久久久久久久久搜平片| 天堂va蜜桃一区二区三区漫画版| 高清在线观看日韩| 日韩一区二区三区在线| 亚洲日本免费电影| 国产成a人无v码亚洲福利| 91精品国产欧美一区二区成人| 18成人在线视频| 国产呦萝稀缺另类资源| 欧美久久久久久久久久| 亚洲日韩欧美一区二区在线| 国内欧美视频一区二区| 欧美一级一区二区| 亚洲韩国精品一区| 99热精品国产| 国产精品视频一二三| 精品一区二区av| 91麻豆精品国产91久久久 | 久久久蜜臀国产一区二区| 首页国产欧美久久| 色哟哟精品一区| 中文字幕字幕中文在线中不卡视频| 国产成人精品综合在线观看| 日韩美女在线视频| 蜜臂av日日欢夜夜爽一区| 欧美精品日韩精品| 亚洲二区在线观看| 在线精品视频免费观看| 亚洲精品视频在线看| 91视频91自| 亚洲精选免费视频| 色哟哟亚洲精品| 亚洲高清三级视频|