※ 引述《ouynln (示山)》之铭言:
: *[36m开发平台(Platform): Win 10
: 编译器(Ex: GCC, clang, VC++...)+目标环境(跟开发平台不同的话需列出)
: VC++
: 额外使用到的函数库(Library Used): (Ex: OpenGL, ...)
: 问题(Question): 如何将txt档内的矩阵资料读取出来,因为txt档内的资
: 料不只有数字,还有其他英文夹杂,而档案内有两笔矩阵资料,需要分别储存,之后
: 要做运算。
: 喂入的资料(Input): txt档内容:
: Matrix_Multiplication
: Name : A1
: 1 2 3 ;
: 4 5 6 ;
: 7 5 9 ;
: Name : B1
: 2 2 3 ;
: 4 5 5 ;
: 8 8 7 ;
: End_Matrix_Multiplication
: 预期的正确结果(Expected Output):
: 错误结果(Wrong Output):
: 程式码(Code):(请善用置底文网页, 记得排版)
: 补充说明(Supplement): 我的想法是用getline()去做,遇到A1则下面
: 的数字开始做储存,同理,遇到B2也是一样。但从一开始就不知如何读取矩阵,
: 希望版上高手可以指导一下小弟这个初学者。(用C++写的)
用 two pass 的方式处理
1.
ifstream(file_name, ios_base::binary);
vector<string> lines;
string s;
while(getline(ifs, s))
lines.push_back(s);
2.
for(size_t i = 0; i < lines.size(); ++i)
{
//...
}
你的问题应该是卡在这,但已经存入 vector 来回导航就比较容易了,
按照你的描述,阵列都是位于:
Name: Ax
//...
Name: Bx
或
Name: Bx
//...
End_Matrix
如果你要判断 Name: [A-Z][0-9],说实在用 Regex 比较简单,
而且好像应该改用 Python 才对?如果你不用 Regex(我个人比较
常用 PCRE),我知道的方法就是直接去拆解字串了
我想重点应该是在 matrix,把字串转成数值有几个好用的 C API:
strtol,strtoul,strtod
strtol(const char* str, char** endptr, int base);
strtol 会抛弃碰到的空白字符,直到碰到第一个数字,转换
成 long 回传,重点在于 endptr,他会指向数值字串后的字符
123 456
^
所以你只要写个很简单算法就可以把字串转成阵列中的某一 row
char *ptr = lines[i];
do{
long tmp = strtol(ptr, &ptr, 10);
matrix[i].push_back(tmp);
}while(ptr != 0 && *ptr != ';');
另外一种作法更安全,就是把 "1 2 3 4;"
拆成 "1", "2, "3", "4"
其他语言这是小菜一碟,如果用 Qt 也很简单
QStringList sl = str.split(QRegExp('[\\s;]'));
如果你只有 STL 可以用,请参考 C++ cookbook
http://shop.oreilly.com/product/9780596007614.do
Ch4: Tokenizing a String
到了这个程度我想应该就不用再解释下去了吧 :P