博客
关于我
stringstream字符串流
阅读量:620 次
发布时间:2019-03-13

本文共 1455 字,大约阅读时间需要 4 分钟。

題解

本題要求我們根據输入的第一行數字 N,計算接下來每行資料的整數總和。每行的整數數量不定,最多有20個,每行的字元數不超過200個。程序需要將每行的總和依次輸出。


輸入示例

31 2 320 17 23 54 77 60111 222 333 444 555 666 777 888 999

輸出結果

62514995

程序碼

#include 
#include
#include
using namespace std;int main() { string s; int T, a; cin >> T; getchar(); while (T--) { getline(cin, s); stringstream ss(s); int sum = 0; while (1) { ss >> a; if (ss.fail()) { break; } sum += a; } cout << sum << endl; }}

分析與解碼

該程序的主要功能是根據輸入的數字 T,處理接下來 T 行數據,每行數據包含若干整數。程序將每行數據的整數值相加,然後將總和依次輸出。

主要功能解碼

  • 讀取輸入

    • 使用 cin >> T 读取第一行的整數 T,表示接下來的數據行數。
    • 使用 getchar() 清除首行換行符,避免額外空行。
    • 使用 while (T--) 进行 T 次循環,每次處理一行數據。
  • 讀取每行數據

    • 使用 getline(cin, s) 读取每行的文字數據,儲存於字符串 s
    • 使用 stringstream ss(s) 将字符串數據轉換為字彫流,進行數值處理。
  • 計算每行數據的總和

    • 初始化 sum為 0,儲存當前行數據的累積總和。
    • 使用 while (1) 进行無限迴圈,從字彫流中讀取每個整數 a
    • 使用條件 if (ss.fail()) break; 減少錯誤處理,當字彫流結束時退出迴圈。
    • 每次讀取數值後,將其加至 sum
  • 輸出每行的總和

    • 使用 cout << sum << endl; 將計算得到的行總和輸出。

  • 程序運行流程

  • 讀取數據行數 T

    • 例如,輸入 3 表示接下來有 3 行數據。
  • 逐行處理數據

    • 第一行數據:1 2 3,總和為 6
    • 第二行數據:20 17 23 54 77 60,總和為 251
    • 第三行數據:111 222 333 444 555 666 777 888 999,總和為 4995
  • 結果輸出

    • 每行的總和依次輸出,第一行總和為 6,第二行為 251,第三行為 4995

  • 技術要點總結

  • 字彫流操作

    • 使用 stringstream 可以方便地將文字數據轉換為字彫流,進一步讀取數值。
    • >> 選擇器可以讀取整數、浮點數或其他數據類型。
  • 錯誤控制

    • 使用 ss.fail() 檢查操作是否成功,避免無法中止迴圈或報告錯誤。
  • 數據處理

    • 週邊總和計算,逐個數值讀取並累積,最後一次迴圈結束時自動停止。
  • 輸出格式

    • 使用 endl 保證每行輸出後換行,保持數據格式清晰。

  • 這段程序碼展示了如何高效處理不定長度的數據行,並計算每行的整數總和。

    转载地址:http://ckeaz.baihongyu.com/

    你可能感兴趣的文章
    Netty工作笔记0025---SocketChannel API
    查看>>
    Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
    查看>>
    Netty工作笔记0077---handler链调用机制实例4
    查看>>
    Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
    查看>>
    Netty常见组件二
    查看>>
    netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
    查看>>
    Netty核心模块组件
    查看>>
    Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
    查看>>
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>
    Netty源码—6.ByteBuf原理二
    查看>>
    Netty源码—7.ByteBuf原理三
    查看>>
    Netty源码—7.ByteBuf原理四
    查看>>
    Netty源码—8.编解码原理二
    查看>>
    Netty源码解读
    查看>>
    Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
    查看>>