注册 登录
编程论坛 C++教室

求设计一个数据文件处理程序,文件中读取字符串生成单词或数据的文件

璐璐嘻嘻 发布于 2017-12-26 15:49, 2697 次点击
设计一个数据文件处理程序
要求:源数据文件中含有字符和数字,从中读取数值数据(将连续的数字字符看成一个数值数据),和读取的单词(将连续的字母字符看成一个单词)分别存放在不同的文件中,并且排序后输出显示。
例如:源数据文件old.dat包括:asjjk 12rtr 345 dasdd9&k32*dfasfkjk##dasfdf897,
则生成的数据文件new1.data包括:12  345  9  32  897
单词文件new2.dat包括:asjjk  rtr  dasdd   k  dfasfkjk  dasfdf
求帮忙c++
6 回复
#2
rjsp2017-12-26 16:01
那 0012#12#09999999999999999999999999999999999999999999
是输出
0012
12
09999999999999999999999999999999999999999999
还是输出
12
12
9999999999999999999999999999999999999999999


然后,你所谓的“排序”又是什么?


#3
rjsp2017-12-26 16:49
程序代码:
#include <iostream>
#include <cctype>
#include <algorithm>
#include <functional>
using namespace std;

int main( void )
{
    const string s = "asjjk 12rtr 345 dasdd9&k32*dfasfkjk##dasfdf897";
   

    for( auto itor=cbegin(s); itor!=cend(s); )
    {
        bool is_digit = isdigit(*itor);
        bool is_alpha = isalpha(*itor);

        if( is_digit || is_alpha )
        {
            cout << (is_digit ? "DIGIT: " : "ALPHA: ");
            auto itor_end = std::find_if( itor, end(s), is_digit ? not_fn(::isdigit) : not_fn(::isalpha) );
            cout.write(&*itor,distance(itor,itor_end)) << '\n';
            itor = itor_end;
        }
        else
        {
            itor = std::find_if( itor, end(s), ::isalnum );
        }
    }
}

输出
ALPHA: asjjk
DIGIT: 12
ALPHA: rtr
DIGIT: 345
ALPHA: dasdd
DIGIT: 9
ALPHA: k
DIGIT: 32
ALPHA: dfasfkjk
ALPHA: dasfdf
DIGIT: 897
排序用 std::sort


#4
璐璐嘻嘻2017-12-27 12:29
回复 2楼 rjsp
是第一种那个样子   排序的话就是按顺序输出的  没什么太大的意思
#5
stop12042017-12-28 09:19
回复 4楼 璐璐嘻嘻
你把 cout << (is_digit ? "DIGIT: " : "ALPHA: "); 删了
再把换行改成制表符不就行了
#6
璐璐嘻嘻2018-01-05 14:22
#7
n1608014262018-12-27 14:32
程序报错了,看不懂,不会修改啊
1