存儲轉換
㈠ 樹的存儲結構轉換
//聲明樹中的類以及結點結構,文件名為tree.h
#ifndef TREE_H
#define TREE_H
template <class T>//樹中結點採用孩子兄弟表示法
struct TNode
{
T data;
TNode<T> *firstchild, *rightsib;
};
template <class T>
class Tree
{
public:
Tree( ); //構造函數,初始化一棵樹,其前序序列由鍵盤輸入
~Tree(void); //析構函數,釋放樹中各結點的存儲空間
TNode<T>* Getroot( ); //獲得指向根結點的指針
void PreOrder(TNode<T> *root); //前序遍歷樹
void PostOrder(TNode<T> *root); //後序遍歷樹
void LeverOrder(TNode<T> *root); //層序遍歷樹
private:
TNode<T> *root; //指向根結點的頭指針
void Release(TNode<T> *root); //析構函數調用
};
#endif
//定義類中的成員函數,文件名為tree.cpp
#include<iostream>
#include<string>
#include"tree.h"
using namespace std;
/*
*前置條件:樹不存在
*輸 入:無
*功 能:構造一棵樹
*輸 出:無
*後置條件:產生一棵樹
*/
template<class T>
Tree<T>::Tree( )
{
const int MaxSize = 100;
int end = 0;
int front = 0;
int rear = 0; //採用順序隊列,並假定不會發生上溢
int j = 0;
TNode<T>* queue[MaxSize]; //聲明一個隊列
TNode<T>* tempNode; //聲明指向結點類型的指針
TNode<T>* brotherNode; //工作指針
TNode<T>* q;
T ch;
cout<<"請輸入創建一棵樹的根結點數據"<<endl;
cin>>ch;
root = new TNode<T>;
root->data = ch;
root->firstchild = NULL;
root->rightsib = NULL;
queue[rear++] = root;
while (!end) //若繼續創建樹
{
T ch1,ch2;
cout<<"請輸入創建一棵樹的父結點數據和孩子結點數據"<<endl;
cin>>ch1>>ch2;
TNode<T>* p = new TNode<T>; //生成一個結點
p->data = ch2;
p->firstchild = NULL;
p->rightsib = NULL;
queue[rear++] = p;
tempNode = queue[front];//頭結點出隊,同時對頭元素的標識符後移
while(ch1 != tempNode->data)
tempNode = queue[front++];
if(tempNode->firstchild == NULL) tempNode->firstchild = p;
else{
brotherNode = tempNode->firstchild; //工作指針指向結點的第一個孩子
while (brotherNode != NULL) //若第一個孩子有兄弟結點
{
q = brotherNode;
brotherNode = brotherNode->rightsib;//工作指針指向第一個孩子的右兄弟
}
q->rightsib = p;
}
cout<<"創建結束? 如果結束請按1否則請按0 "<<endl;
cin>>end;
}
}
/*
*前置條件:樹已存在
*輸 入:無
*功 能:釋放樹中各結點的存儲空間
*輸 出:無
*後置條件:樹不存在
*/
template<class T>
Tree<T>::~Tree(void)
{
Release(root);
}
/*
*前置條件:樹已存在
*輸 入:無
*功 能:獲取指向樹根結點的指針
*輸 出:指向樹根結點的指針
*後置條件:樹不變
*/
template<class T>
TNode<T>* Tree<T>::Getroot( )
{
return root;
}
/*
*前置條件:樹已存在
*輸 入:無
*功 能:前序遍歷樹
*輸 出:樹中結點的一個線性排列
*後置條件:樹不變
*/
template<class T>
void Tree<T>::PreOrder(TNode<T> *root) //前序遍歷樹
{
if (root == NULL) return; //遞歸調用的結束條件
else{
cout<<root->data; //列印根節點
PreOrder(root->firstchild); //前序遞歸遍歷root的第一個孩子
PreOrder(root->rightsib); //前序遞歸遍歷root的右兄弟
}
}
/*
*前置條件:樹已存在
*輸 入:無
*功 能:後序遍歷樹
*輸 出:樹中結點的一個線性排列
*後置條件:樹不變
*/
template<class T>
void Tree<T>::PostOrder(TNode<T> *root)
{
if (root == NULL) return; //遞歸調用的結束條件
else{
PostOrder(root->firstchild); //後序遞歸遍歷root的第一個孩子
cout<<root->data; //列印出root結點
PostOrder(root->rightsib); //後序遞歸遍歷root的右兄弟
}
}
/*
*前置條件:樹已存在
*輸 入:無
*功 能:層序遍歷樹
*輸 出:樹中結點的一個線性排列
*後置條件:樹不變
*/
template<class T>
void Tree<T>::LeverOrder(TNode<T> *root)
{
const int MAX_QUEUE_SIZE = 100;
int front = 0;
int rear = 0; //採用順序隊列,並假定不會發生上溢
TNode<T>* queue[MAX_QUEUE_SIZE]; //聲明一個隊列
TNode<T>* tempNode; //聲明指向結點類型的指針
TNode<T>* brotherNode; //工作指針
if (root == NULL) return;//循環結束條件
queue[rear++] = root; //否則結點入隊
while (front != rear) //若隊列中有結點
{
tempNode = queue[front++];//頭結點出隊,同時對頭元素的標識符後移
cout<<tempNode->data; //列印出頭結點
brotherNode = tempNode->firstchild; //工作指針指向結點的第一個孩子
while (brotherNode != NULL) //若第一個孩子有兄弟結點
{
queue[rear++] = brotherNode; //第一個孩子結點入隊
brotherNode = brotherNode->rightsib;//工作指針指向第一個孩子的右兄弟
}
}
}
/*
*前置條件:樹已經存在
*輸 入:無
*功 能:釋放樹的存儲空間,析構函數調用
*輸 出:無
*後置條件:樹不存在
*/
template <class T>
void Tree<T>::Release(TNode<T>* root)
{
if (root != NULL){
Release (root->firstchild); //釋放第一個孩子
Release (root->rightsib); //釋放右兄弟
delete root;
}
}
//有關樹的實現的主函數,文件名為treemain.cpp
#include <iostream>
#include <string>
#include"tree.cpp"
using namespace std;
void main()
{
Tree<string> t; //創建一棵樹
TNode<string>* p = t.Getroot( ); //獲取指向根結點的指針
cout<<"------前序遍歷------ "<<endl;
t.PreOrder(p);
cout<<endl;
cout<<"------後序遍歷------ "<<endl;
t.PostOrder(p);
cout<<endl;
cout<<"------層序遍歷------ "<<endl;
t.LeverOrder(p);
cout<<endl;
}
㈡ 如何把系統硬碟轉換為普通存儲硬碟
摘要 您好,系統盤可以直接存儲文件的
㈢ 怎麼把電腦里的存儲位置從c盤轉換到d盤
完全可以轉移到d盤,e盤或其它位置的。如下說明: 往往不同的軟體保存路徑有默認的位置,也可以人工另存為指定路徑的,有的軟體會隨著前面指定的保存路徑,而繼續執行前面的路徑保存的。 有些軟體有自動備份功能,並可以設置備份的時間間隔、路徑的,默認的路徑可以指定位置,也可以保存在C盤,也可以在軟體安裝目錄的某一個文件夾里。 自動保存的文件也是可以隨便移動的,不過,需要記牢路徑,以免以後找不到。 很多軟體指定下載保存的文件夾,也可以不用並刪除指定的文件夾,自己指定文件夾。 所以一定要記住文件保存的路徑和名稱。
㈣ 存儲容量單位的換算
一般內存換算是1024進制,也就是2的10次方。
1TB=1024GB;
1GB=1024MB;
1MB=1024KB;
1KB=1024Byte。
㈤ 數據存儲單位的換算單位
換算率約等於1000(1024),從大到小順序為T、GB、MB(兆Zhao)、KB、B再小就是位(比特)了。
1TB=1024GB 1GB=1024MB 1MB=1024KB 1KB=1024B 1B=8b
計算機存儲單位一般用bit、B、KB、MB、GB、TB、PB、EB、ZB、YB、BB、NB、DB……來表示,它們之間的關系是:
位 bit (比特)(Binary Digits):存放一位二進制數,即 0 或 1,最小的存儲單位。[英文縮寫:b(固定小寫)]
位元組byte:8個二進制位為一個位元組(B),最常用的單位。
1 Byte(B) = 8 bit
1 Kilo Byte(KB) = 1024B
1 Mega Byte(MB) = 1024 KB
1 Giga Byte (GB)= 1024 MB
1 Tera Byte(TB)= 1024 GB
1 Peta Byte(PB) = 1024 TB
1 Exa Byte(EB) = 1024 PB
1 Zetta Byte(ZB) = 1024 EB
1Yotta Byte(YB)= 1024 ZB
1 Bronto Byte(BB) = 1024 YB
1Nona Byte(NB)=1024 BB
1 Dogga Byte(DB)=1024 NB
1 Corydon Byte(CB)=1024DB
1 Xero Byte(XB)=1024CB
注意上面Kibi這一系列的定義。Kibi來自英語kilo-binary(二進制的千), 1998年10月在IEC60027-2中訂位標准。但到目前在各種應用中還沒有完全占優勢。
在信息行業中常用用於內存容量的MB、 GB,幾乎都是指220,230,… 數位組。KB也經常表示210數位組,以區別於kB。當然你也會經常看到kB被混用來表示210數位組。這些表示法都並沒有被標准化。
至於硬碟容量,一般的製造商總是用十進制的計數。一般計算機的操作系統都是使用二進制的計數,所以你經常會發現在計算機看到的硬碟容量比硬碟上的實際可用容量要小,比如20GB的硬碟只顯示有18.6GB。
特別誤導人是軟盤的情況。720KB的軟盤是720×1024個數位組的值經常用2個十六進制的數字(在信息科學中這樣一個16進制的數字也稱為一),而1.44MB的軟盤則莫名奇妙的是1.44×1000×1024個數位組的值經常用兩個十六進制的數字(在信息科學中這樣一個16進制的數字也稱為一),即不全是十進制也不全是二進制。
註:「兆」為百萬級數量單位。
附:進制單位全稱及譯音
yotta,[堯]它, Y. 10^24,
zetta,[澤]它, Z. 10^21,
exa,[艾]可薩, E. 10^18,
peta,[拍]它, P. 10^15,
tera,[太]拉, T. 10^12,
giga,[吉]咖, G. 10^9,
mega,[兆],M. 10^6
㈥ 二叉樹存儲轉換
第三層第五個節點
㈦ 內存卡怎樣轉換儲存格式
是什麼東西轉換內存卡儲存??
藍牙傳送的文件
信息
如果是
那你就按下列路徑操作
:
信息
-選項
-設置
-其他 -
儲存方式 -
儲存卡儲存
【夏天n72解答
】
㈧ 存儲過程類型轉換
自己寫的么?
1有些地方沒必要4個單引號,3個就行,在sql中字元串的拼接語句中要表示1個單引號就得用兩個單引號,前一個表示轉義的意思,編程語言都有轉義一說
2因為是字元串拼接的,而@FormerPrice這些是money類型的,如果不轉換,就默認要把字元串轉換成money類型了,就會出錯。所以得把@FormerPrice之類的轉換成字元類型的,存儲過程修改如下
ALTER PROCEDURE [dbo].[SearchMerchandise]
@Category varchar(50),
@Brand varchar(50),
@Type varchar(50),
@FormerPrice money,
@LatterPrice money
AS
BEGIN
declare @QueryString varchar(100)
set @QueryString = 'select * from Merchandise where Category = ''' + @Category + ''' and Brand = ''' + @Brand + ''' '
SET NOCOUNT ON;
if @Type<>''
set @QueryString = @QueryString+' and Type=''' +@Type+ ''''
if @FormerPrice<>'' and @LatterPrice<>''
set @QueryString = @QueryString+' and PriceNow between '''+ convert(varchar(20),@FormerPrice) + ''' and ''' + convert(varchar(20),@LatterPrice) + ''''
if @FormerPrice<>'' and @LatterPrice=''
set @QueryString = @QueryString+' and PriceNow >=''' + convert(varchar(20),@FormerPrice) + ''''
if @FormerPrice='' and @LatterPrice<>''
set @QueryString = @QueryString+' and PriceNow <=''' + convert(varchar(20),@LatterPrice) + ''''
exec(@QueryString)
END
因為沒有表結果不能進行測試,所以可能會出錯,如果出錯就把表結果發一下,進行測試
㈨ 怎樣修改手機存儲類型轉換
設置——存儲——存儲類型。
㈩ S7568內外儲存怎麼轉換
個人覺得,那機器也就那樣了,有時間精力搗騰那破玩意,不如換個高端點的。本來各方面性能就不咋的,轉換需要ROOT,三星都是一個調調網路就知道了,不過那樣傷機器,很容易導致字型檔崩潰,9300就是例子。