簡體   English   中英

c ++中的cout浮點格式

[英]cout floating point format in c++

std::ostream& operator<<(std::ostream& o, const mat4& m)
{
    o << std::setprecision(6) << std::fixed << std::right;
    const int w = 8;
    for (int i = 0; i < 4; i++)
    {
        int j = 4 * i;
        o << '[' << std::setw(w) << m[j] << ',' << std::setw(w) << m[1 + j] << ',' << std::setw(w)  <<  m[2 + j] << ',' << std::setw(w) << m[3 + j] << ']' << std::endl;
    }

    return o;
}

我想將數據打印為:

[-1.00000, 1.00000, 123.000,-23.0000]

這是我要實現的目標:

  • 如果負號不存在,請添加一個空格
  • 字符串的大小是固定的,並且僅顯示最高有效值

我正在考慮使用std::fixedstd::scientific但無法弄清楚如何使用iomanip實現上述格式。 甚至可以使用iomanip完成此操作,還是需要實現自己的方法?

您想要setiosflags(ios_base::showpoint)

#include <iomanip>
#include <iostream>

int main()
{
  double m[] = {-1, 1, 123, -23};
  const int w = 8;
  std::cout << std::setiosflags(std::ios_base::showpoint);
  std::cout << '[' << std::setw(w) << m[0] << ',' << std::setw(w) << m[1] << ',' << std::setw(w)  <<  m[2] << ',' << std::setw(w) << m[3] << ']' << std::endl;
}

結果是:

[-1.00000, 1.00000, 123.000,-23.0000]

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM