c++ stringstream(老好用了)

前言:

? ? 以前沒有接觸過stringstream這個類的時候,常用的字符串和數字轉換函數就是sscanf和sprintf函數。開始的時候就覺得這兩個函數應經很叼了,但是畢竟是屬于c的。c++中引入了流的概念,通過流來實現字符串和數字的轉換方便多了。在這里,總結之前的,并介紹新學的。

常見格式串:  

  %% 印出百分比符號,不轉換。
  %c 整數轉成對應的 ASCII 字元。
  %d 整數轉成十進位。
  %f 倍精確度數字轉成浮點數。
  %o 整數轉成八進位。
  %s 整數轉成字符串。
  %x 整數轉成小寫十六進位。
  %X 整數轉成大寫十六進位。
  %n sscanf(str, "%d%n", &dig, &n),%n表示一共轉換了多少位的字符

sprintf函數

   sprintf函數原型為 int sprintf(char *str, const char *format, ...)。作用是格式化字符串,具體功能如下所示:

  (1)將數字變量轉換為字符串。

  (2)得到整型變量的16進制和8進制字符串。

  (3)連接多個字符串。

int main(){char str[256] = { 0 };int data = 1024;//將data轉換為字符串sprintf(str,"%d",data);//獲取data的十六進制sprintf(str,"0x%X",data);//獲取data的八進制sprintf(str,"0%o",data);const char *s1 = "Hello";const char *s2 = "World";//連接字符串s1和s2sprintf(str,"%s %s",s1,s2);cout<<str<<endl; return 0;
} 

sscanf函數

  sscanf函數原型為int sscanf(const char *str, const char *format, ...)。將參數str的字符串根據參數format字符串來轉換并格式化數據,轉換后的結果存于對應的參數內。具體功能如下:

  (1)根據格式從字符串中提取數據。如從字符串中取出整數、浮點數和字符串等。

  (2)取指定長度的字符串

  (3)取到指定字符為止的字符串

  (4)取僅包含指定字符集的字符串

  (5)取到指定字符集為止的字符串

  當然,sscanf可以支持格式串"%[]"形式的,有興趣的可以研究一下。

int main(){char s[15] = "123.432,432";int n;double f1;int f2;sscanf(s, "%lf,%d%n", &f1, &f2, &n);cout<<f1<<" "<<f2<<" "<<n;return 0;
} 

  輸出結果:123.432 432 11, 即一共轉換了11位的字符。

stringstream類:

  <sstream>庫定義了三種類:istringstream、ostringstream和stringstream,分別用來進行流的輸入、輸出和輸入輸出操作。

  1.stringstream::str(); returns a string object with a copy of the current contents of the stream.

  2.stringstream::str (const string& s); sets s as the contents of the stream, discarding any previous contents.

  3.stringstream清空,stringstream s; s.str("");

  4.實現任意類型的轉換

    template<typename out_type, typename in_value>
    out_type convert(const in_value & t){
      stringstream stream;
      stream<<t;//向流中傳值
      out_type result;//這里存儲轉換結果
      stream>>result;//向result中寫入值
      return result;
    }

int main(){string s = "1 23 # 4";stringstream ss;ss<<s;while(ss>>s){cout<<s<<endl;int val = convert<int>(s);cout<<val<<endl;}return 0;
}

  輸出:1 1 23 23 # 0 4 4

  

  順便說一下,今天做題的時候也用到了stringstream這個類,是二叉樹的序列化和反序列化。

  題目鏈接:http://www.lintcode.com/zh-cn/problem/binary-tree-serialization/

二叉樹的序列化和反序列化

  設計一個算法,并編寫代碼來序列化和反序列化二叉樹。將樹寫入一個文件被稱為“序列化”,讀取文件后重建同樣的二叉樹被稱為“反序列化”。如何反序列化或序列化二叉樹是沒有限制的,你只需要確保可以將二叉樹序列化為一個字符串,并且可以將字符串反序列化為原來的樹結構。

思路:

  通過先序遍歷建立二叉樹的序列化,其中空子樹用'#'來表示。反序列化的時候呢,遇到'#'就停止遞歸構造。另外序列化的時候是將整數通過stringstream轉換成字符串,反序列化是將字符串通過stringstream轉換成整數。

/*** Definition of TreeNode:* class TreeNode {* public:*     int val;*     TreeNode *left, *right;*     TreeNode(int val) {*         this->val = val;*         this->left = this->right = NULL;*     }* }*/
class Solution {
public:/*** This method will be invoked first, you should design your own algorithm * to serialize a binary tree which denote by a root node to a string which* can be easily deserialized by your own "deserialize" method later.*/bool first;template<typename out_type, typename in_value>out_type convert(const in_value & t){stringstream stream;stream<<t;//向流中傳值out_type result;//這里存儲轉換結果stream>>result;//向result中寫入值return result;}void pre_order(TreeNode *root, string &s){if(root){string tmp = convert<string>(root->val);if(!first)s+= " "+tmp;else {first = false;s+=tmp;}pre_order(root->left, s);pre_order(root->right, s);} else {if(first)s+='#';else {first = false;s+=" #";}}}string serialize(TreeNode *root) {// write your code herestring s="";first = true;pre_order(root, s);//先序實現序列化return s;}stringstream ss;void buildT(TreeNode * &T){string s;ss>>s;if(s == "#") return ;int val = convert<int>(s);T = new TreeNode(val);buildT(T->left);buildT(T->right);}/*** This method will be invoked second, the argument data is what exactly* you serialized at method "serialize", that means the data is not given by* system, it's given by your own serialize method. So the format of data is* designed by yourself, and deserialize it here as you serialize it in * "serialize" method.*/TreeNode *deserialize(string data) {// write your code hereTreeNode *T = NULL;ss.str("");ss<<data;buildT(T);return T;}
};

?

轉載于:https://www.cnblogs.com/hujunzheng/p/5042068.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/531371.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/531371.shtml
英文地址,請注明出處:http://en.pswp.cn/news/531371.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

mount --bind的用處

&#xff08;一&#xff09;mount --bind介紹 mount --bind的作用是將兩個目錄連接起來&#xff0c;例如&#xff1a;mount ---bind /dir1 /dir2 是將dir1目錄掛載到dir2目錄上&#xff0c;下面來實際演示一下&#xff1a; 上面的操作中首先創建了dir1 dir2兩個目錄&#xf…

gcc -strip編譯選項的作用

從字面上來看strip的意思是脫衣服、拆卸&#xff0c;那么gcc --strip的作用大概能猜錯來了。 沒錯就是有選擇地除去行號信息、重定位信息、調試段、typchk 段、注釋段、文件頭以及所有或部分符號表。 一旦使用該命令&#xff0c;則很難調試文件的符號&#xff0c;因此&#x…

lintcode 落單的數(位操作)

題目1 落單的數 給出2*n 1 個的數字&#xff0c;除其中一個數字之外其他每個數字均出現兩次&#xff0c;找到這個數字。 鏈接&#xff1a;http://www.lintcode.com/zh-cn/problem/single-number/ 樣例 給出 [1,2,2,1,3,4,3]&#xff0c;返回 4 挑戰 一次遍歷&#xff0c;常數級…

旋轉圖像

旋轉圖像 給定一個NN的二維矩陣表示圖像&#xff0c;90度順時針旋轉圖像。 看個例子 算法1&#xff1a; 如上圖所示&#xff0c;設一個N階二維矩陣&#xff0c;則將矩陣從外向里可以分成N/2個圈&#xff0c;例如&#xff08;1 2 3 4 8 12 16 15 14 13 9 5&#xff09;這是最外邊…

嵌入式開發板模擬器:QEMU

前兩天看微信公眾號時發現了一個嵌入式模擬器&#xff0c;感覺很不錯&#xff0c;自己動手安裝了一個&#xff0c;折騰了幾天&#xff0c;下載一直是個問題&#xff0c;特此記錄如下 模擬器大家應該都聽說過&#xff0c;有的小伙伴打游戲也會安裝模擬器&#xff0c;今天我們介紹…

gcc: weak_alias如何使用

本文主要說明weak和alias是什么和如何使用它 __attribute__是用來說明函數的屬性&#xff0c;weak和alias分別是兩個屬性。 &#xff08;一&#xff09;強符號和弱符號&#xff1a; 強符號&#xff1a;已經初始化的全局變量和未被weak修飾的函數弱符號&#xff1a;未初始化的全…

靜態Include和動態Include測試并總結

主要代碼 hjzgg.css .center-div{width:auto;margin-left: 40%;margin-right: 40%;display: block;position: absolute;top:0px;left:0px; }.text-div{margin-top: 80px; }.hjzgg-div{color:transparent;font-size:20px;font-weight: bold;letter-spacing:2px;-webkit-animatio…

linux終端常用快捷鍵

CTRLALTT 打開終端 CTRLD 關閉終端 CTRL SHIFT "" 放大終端字體 CTRL “-” 縮小終端字體 CTRL r 查找歷史命令 CTRLu 刪除光標前面所有內容 CTRLw 刪除光標左邊的單詞 CTRL k 刪除光標后面的所有內容 CTRLL 清除當前屏幕內容 CTRLa 光標移到開始位置 CTRLe 光標移到…

ueditor的配置和使用

ueditor下載好之后直接復制到項目的WebContent目錄下&#xff0c;并將ueditor\jsp\lib下的jar包復制或者剪切到項目的lib目錄下。先看一下效果&#xff0c;如下&#xff1a; 1.文件的上傳 首先在ueditor/jsp目錄下找到config.json文件&#xff0c;就拿Image上傳來說吧。 "…

windows上搭建NFS服務器

在進行嵌入式開發的時候&#xff0c;我們常用的做法是搭建NFS服務器&#xff0c;然后使把文件系統、調試程序放在NFS服務器上&#xff0c;這樣可以方便調試&#xff0c;以前都是在linux里面開啟NFS服務器&#xff0c;今天來說下window里的nfs服務器–haneWin 一、軟件安裝和使…

計算機是如何啟動的?從未上電到操作系統啟動

計算機是如何啟動的&#xff0c;網絡上很多博文1都從 BIOS 程序的加載開始說起&#xff0c;有的也跳到 BIOS 程序加載 Bootloader 階段。個人認為把這個過程稱為操作系統是如何被加載并啟動應該更加貼切一點。同時&#xff0c;也有計算機硬件大神的文章[1][5]詳細分析計算機加電…

Hibernate注解

前言&#xff1a; 最近正在學習Hibernate通過注解&#xff08;annotation&#xff09;來管理映射關系&#xff0c;以前都是通過XML映射文件。下面拿個小例子說一下。 數據庫物理模型&#xff1a; 數據庫的描述&#xff1a; 一篇博客隨筆可以分到不同的類中&#xff0c;一個類中…

js表單動態添加數據并提交

情景1&#xff1a;已經存在form對象了&#xff0c;動態為form增加對象并提交 function formAppendSubmit(){var myform$(#newArticleForm); //得到form對象var tmpInput$("<input typetext nameblogArticleForm.articleContent/>");tmpInput.attr("value&…

*++p和*p++的區別

首先你應該明白* 和 的優先級是相同的&#xff0c;而且他們的結合性是從又往左的 #include <stdio.h>int main(int argc ,char * argv[]) {int str[]{1,2,3,4,5,6,7,8,9,10};int *p str;int a *p;//a*p ,pp1即a1&#xff0c;p&str[1]int b *p;//pp1,b*p即p&s…

zyUpload+struct2完成文件上傳

前言&#xff1a; 最近在寫自己的博客網站&#xff0c;算是強化一下自己對s2sh框架的理解。期間遇到了很多問題&#xff0c;這些問題在寫之前都考慮過&#xff0c;感覺也就是那樣吧。但正真遇到了&#xff0c;也挺讓人難受的。就利用zyUpload這個js插件實現文件的上傳&#xff…

gbd的簡單使用(一)

這篇文章將gdb的簡單使用&#xff0c;通過此篇文章你能學習到使用gdb進行調試程序 在Linux中編寫程序時&#xff0c;如何進行程序的debug工作呢&#xff1f;今天來介紹下gdb這個工具&#xff0c;可以在Linux下直接man gdb查看幫助信息 &#xff08;一&#xff09;gdb命令介紹 …

java發送內嵌圖片郵件

前言&#xff1a; 博客系統中需要郵件服務的功能&#xff0c;以前寫過類似的功能&#xff0c;不過功能太簡單了&#xff0c;僅僅是發送文本內容&#xff0c;現在嘗試一下發送內嵌圖片郵件&#xff01; 準備工作&#xff1a; 請參考&#xff1a;http://www.cnblogs.com/hujunzhe…

調試跟蹤利器---strace

通過這篇文章你會學習到strace的用法&#xff0c;strace可以幫助你高效地定位進程中的一些錯誤&#xff0c;關于strace的用處有很多&#xff0c;可以自行發掘 前面我們講解了gdb調試程序,這篇文章介紹另一個調試跟蹤工具strace&#xff0c;同樣你可以在linux下執行man strace查…

MBR、DBR、FAT32基礎小知識

MBR-------主引導記錄 1.創建時間&#xff1a;由分區軟件&#xff08;Fdisk/PartitionMagic/Windows 2000/Windows XP安裝 工具等&#xff09;給 硬盤分區時建立的。 2.功能 &#xff1a;存放硬盤分區信息和引導系統時檢查分區。 3.作用范圍&#xff1a;MBR和虛擬MBR控制著整個…

java使用Executor(執行器)管理線程

一.一個實現了Runnable接口的類 class MyThread implements Runnable{private static int num 0;Overridepublic void run() {while(true){synchronized(MyThread.class){num;try{Thread.sleep(500);} catch(Exception e){System.out.println(e.toString());}System.out.print…