我有一張地圖,定義爲map<string, vector<double> >
。以表格形式打印STL地圖
如何將其作爲表格打印。我要地圖的關鍵是表的標題行和表的每一列將是vector
說我的初始地圖是
hash = {
"a": [1, 2, 3],
"b": [1, 2, 3]
}
我想這個打印爲
a b
1 1
2 2
3 3
我有一張地圖,定義爲map<string, vector<double> >
。以表格形式打印STL地圖
如何將其作爲表格打印。我要地圖的關鍵是表的標題行和表的每一列將是vector
說我的初始地圖是
hash = {
"a": [1, 2, 3],
"b": [1, 2, 3]
}
我想這個打印爲
a b
1 1
2 2
3 3
下面是使用C++ 11的可能實現(在這裏我希望所有向量具有相同的大小):
#include <map>
#include <string>
#include <vector>
#include <iostream>
void print(std::map<std::string, std::vector<double>> const& m)
{
// Do nothing for an empty table...
if (m.begin() == m.end()) { return; }
for (size_t i = 0; i <= m.begin()->second.size(); i++)
{
for (auto const& p : m)
{
if (i == 0) { std::cout << p.first << " "; }
else { std::cout << p.second[i - 1] << " "; }
}
std::cout << std::endl;
}
}
int main()
{
std::map<std::string, std::vector<double>> m = {
{ "a", { 1, 2, 3, 0 } },
{ "b", { 2, 4, 6, 1 } },
{ "c", { 9, 2, 3, 2 } }
};
print(m);
}
這裏是一個live example。
+1 for C++ 11更簡潔優雅 – gongzhitaao 2013-03-21 17:18:05
這只是打印矢量字段的前三個值 – subzero 2013-03-21 17:20:55
@subzero:它最初是,但我更新了我的答案(請參閱鏈接的實例) – 2013-03-21 17:24:15
#include <iostream>
#include <map>
#include <string>
#include <vector>
using namespace std;
int main()
{
map<string, vector<double> > m;
vector<double> a, b, c;
for (int i = 0; i < 4; ++i) a.push_back(i);
for (int i = 0; i < 6; ++i) b.push_back(i);
for (int i = 0; i < 7; ++i) c.push_back(i);
m["a"] = a;
m["b"] = b;
m["c"] = c;
int n = max(max(a.size(), b.size()), c.size());
for (map<string, vector<double> >::iterator i = m.begin(); i != m.end(); ++i)
cout << i->first << ',';
cout << endl;
for (int i = 0; i < n; ++i) {
for (map<string, vector<double> >::iterator it = m.begin(); it != m.end(); ++it)
cout << (i < it->second.size() ? it->second[i] : 0) << ',';
cout << endl;
}
}
我相信有更好的方法來完成這樣的迭代以及處理後,
。
彈性任意列和變體長度
void print(const map<string, vector<double>> &m)
{
size_t rows = 0;
for (auto const &i : m)
{
cout << i.first << ' ';
if (i.second.size() > rows)
rows = i.second.size();
}
cout << endl;
for (size_t r = 0; r < rows; ++r)
{
for (auto const &i : m)
if (r < i.second.size())
cout << i.second[r] << " ";
else
cout << " ";
cout << endl;
}
}
int main()
{
map<string, vector<double> > m = {
{ "a", { 1, 2, 3}},
{ "b", { 1, 2, 3, 4}},
{ "c", { 1, 2}},
{ "d", { 1}},
{ "e", { 1, 2, 3, 4, 5, 6, 7}}
};
print(m);
}
輸出
a b c d e
1 1 1 1 1
2 2 2 2
3 3 3
4 4
5
6
7
Live源代碼。
該解決方案適用於任意數量的列,每列都有任意數量的行。
並且列名也具有任意長度。
#include <map>
#include <string>
#include <vector>
#include <iostream>
void print(std::map<std::string, std::vector<double>> const& m)
{
std::vector<size_t> columnWidths;
std::vector< std::vector<std::string>> columns;
size_t totalRows = 0;
// Store all table elements, and the required width of each column
for (auto a : m)
{
std::vector<std::string> column;
size_t width = a.first.length();
column.push_back(a.first);
size_t rows = 1;
for (auto v : a.second)
{
++rows;
std::string entry = std::to_string(v);
width = std::max(width, entry.length());
column.push_back(entry);
}
columnWidths.push_back(width);
columns.push_back(column);
totalRows = std::max(totalRows, rows);
}
// Print all table elements
for (size_t row = 0; row != totalRows; ++row)
{
for (size_t col = 0; col != columns.size(); ++col)
{
std::string entry;
if (columns[col].size() > row)
{
entry = columns[col][row];
}
entry.resize(columnWidths[col], ' ');
std::cout << entry << ' ';
}
std::cout << '\n';
}
}
int main()
{
std::map<std::string, std::vector<double>> m =
{
{ "a", { 1, 2, 3} },
{ "a really really long string", { 1, 2, 3} },
{ "b", { 1, 2, 3, 4, 5 } }
};
print(m);
}
這適用於矢量長度不同:
#include <iostream>
#include <map>
#include <vector>
#include <string>
using namespace std;
int main()
{
map<string,vector<double> > hashes;
double arr[]={1,2,3};
double arr2[]={1,2,3,4};
hashes.insert(pair<string,vector<double> >("a",vector<double>(arr,arr+sizeof(arr)/sizeof(double))));
hashes.insert(pair<string,vector<double> >("b",vector<double>(arr,arr+sizeof(arr)/sizeof(double))));
hashes.insert(pair<string,vector<double> >("c",vector<double>(arr2,arr2+sizeof(arr2)/sizeof(double))));
for(auto i: hashes)
{
cout<< i.first << ' ';
}
cout << endl;
int max_len=0;
for(auto i: hashes)
{
if(i.second.size()>max_len) max_len=i.second.size();
}
for(int h=0; h<max_len; h++)
{
for(auto i: hashes)
{
if(h>=i.second.size()) cout << " ";
else cout << i.second[h] << " ";
}
cout << endl;
}
return 0;
}
輸出:
a b c
1 1 1
2 2 2
3 3 3
4
你需要它是有道理的,還是你只需要空格界定? – Wug 2013-03-21 16:51:46
whitesapce分隔...基本上我想寫它到一個csv文件 – subzero 2013-03-21 16:54:11
所有的載體保證是相同的大小? – metal 2013-03-21 16:56:15