c++ stringstream(老好用了)

C++字符串与数字转换
本文介绍了C++中字符串与数字之间的多种转换方法,包括使用sscanf和sprintf函数,以及更高级的stringstream类的使用技巧。并通过实例展示了二叉树序列化与反序列化的实现。

http://www.cnblogs.com/hujunzheng/p/5042068.html

  

v前言:

    以前没有接触过stringstream这个类的时候,常用的字符串和数字转换函数就是sscanf和sprintf函数。开始的时候就觉得这两个函数应经很叼了,但是毕竟是属于c的。c++中引入了流的概念,通过流来实现字符串和数字的转换方便多了。在这里,总结之前的,并介绍新学的。

v常见格式串:  

  %% 印出百分比符号,不转换。
  %c 整数转成对应的 ASCII 字元。
  %d 整数转成十进位。
  %f 倍精确度数字转成浮点数。
  %o 整数转成八进位。
  %s 整数转成字符串。
  %x 整数转成小写十六进位。
  %X 整数转成大写十六进位。
  %n sscanf(str, "%d%n", &dig, &n),%n表示一共转换了多少位的字符

vsprintf函数

   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和s2
    sprintf(str,"%s %s",s1,s2);
    cout<<str<<endl; 
    return 0;
} 
复制代码

vsscanf函数

  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位的字符。

vstringstream类:

  <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/

v二叉树的序列化和反序列化

  设计一个算法,并编写代码来序列化和反序列化二叉树。将树写入一个文件被称为“序列化”,读取文件后重建同样的二叉树被称为“反序列化”。如何反序列化或序列化二叉树是没有限制的,你只需要确保可以将二叉树序列化为一个字符串,并且可以将字符串反序列化为原来的树结构。

v思路:

  通过先序遍历建立二叉树的序列化,其中空子树用'#'来表示。反序列化的时候呢,遇到'#'就停止递归构造。另外序列化的时候是将整数通过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 here
        string 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 here
        TreeNode *T = NULL;
        ss.str("");
        ss<<data;
        buildT(T);
        return T;
    }
};
复制代码

 

版权声明:本文原创发表于博客园,作者为小眼儿。 本文欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则视为侵权。
工作之余: lintcode简单题目解析 lintcode lintcode中等题目解析


  
#1楼   2015-12-14 10:59  envoy   
不幸的是,它的性能很差。



<think>好的,用户需要的是用上海话表达天气变化的句子,具体例子是“天边来了一片云落了一场雨天气很好”。首先,得理解用户的需求,他们可能想学习上海话中描述天气的常用表达,或者想用方言更生动地描述天气变化。需要先确认上海话中常用的词汇和句式结构。接下来,得分析用户提供的句子结构。原句分为两部分:前半部分描述天气变化(云来了,下雨了),后半部分说天气很好。可能需要注意上海话中的语序和用词差异,比如动词的位置、量词的使用等。例如,“一片云”在上海话中可能会用“一朵云”或者不同的量词。 然后,考虑上海话的发音和用词习惯。比如“天边”在上海话中可能说“天浪向”或者“天旁边”,“落雨”是常用的说法。需要确保翻译后的句子符合上海话的表达习惯,而不仅仅是直译普通话。 还需要查找是否有现成的上海话教材或网络资源中的类似例句,确认常用的表达方式。比如,上海话中常用“落雨”而不是“下雨”,“天气好”可能会说“天气好”或者“天气赞”。另外,要注意句子的连贯性,确保前后部分衔接自然。比如前半部分描述下雨,后面说天气好,可能需要适当的转折词,或者根据实际情况调整,比如雨后的晴朗。最后,整合这些信息,形成符合上海话语法和用词习惯的句子,并检查是否自然流畅。可能需要多个版本,供用户选择。同时,考虑是否需要添加注音或拼音,帮助用户正确发音。完成翻译后,按照用户要求生成相关问题,这些问题应围绕上海话的天气表达、语法结构或日常用语,确保相关且有助于用户进一步学习。</think>根据上海话的表达习惯和语法特点,"天边来了一片云落了一场雨 天气很好"可转换为以下两种常见表述方式: **1. 天浪向飘过来一朵乌云,落脱一埭雨,现在天气倒蛮嗰** - "天浪向"对应普通话"天边" - "落脱一埭雨"中"埭"(da)是上海话特有量词 - "倒蛮嗰"表示转折语气 **2. 天旁边飘来块黑云头,落仔阵头雨,过脱一歇歇天又放晴了** - "阵头雨"指雷阵雨 - "过脱一歇歇"表示"过了一会儿" - "放晴"使用动词+补语结构 上海话语法特点: 1. 量词使用差异:"片"对应"朵/块" 2. 时态表达:"落仔"(落了)包含完成时态 3. 倒装结构常见:"落雨哉"代替"下雨了" 发音要点: - "嗰"读作[geʔ](短促入声) - "埭"读[da](阳去声) - "歇"读[xɪʔ](入声) ``` # 上海话拼音示例 tin lang xiang piao kwe wu yun deu 天 浪向 飘 块 乌 云 头 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值