Даны две строки символов, состоящих из цифр, букв и пробелов. группу символов, не содержащих пробелов внутри себя, будем называть словами. составить программу переформирования строк так, чтобы в первой строке располагались слова, начинающиеся с цифр, в порядке их возрастания, а во второй – слова, начинающиеся с букв, в алфавитном порядке. перевести из pascal в с++ begin var s1: =readlnstring('строка 1: '); var s2: =readlnstring('строка 2: '); var s: =(s1+' '+s2).towords; s1: =s.where(t-> t[1] in ['0'..'9']).orderby(t-> t).joinintostring; s1.println; s2: =s.where(t-> not(t[1] in ['0'..'9'(t-> t).joinintostring; s2.println end.

aresu aresu    2   26.09.2019 19:30    0

Ответы
Bereke2006 Bereke2006  08.10.2020 20:57
Незнаю верно ли я все понял, но как вариант можно сделать так
//Microsoft (R) C/C++ Optimizing Compiler Version 19.00.23506 for x64

#include <iostream>
#include <string>
#include <sstream>
#include <vector>
#include <iterator>
#include <algorithm>

bool DigitFirst(const std::string& rhs, const std::string& lhs)
{
    if (isdigit(rhs[0]) || isdigit(lhs[0]))
        return rhs < lhs;
}

bool LetterFirst(const std::string& rhs, const std::string& lhs)
{
    if (isalpha(rhs[0]) || isalpha(lhs[0]))
        return rhs < lhs;
}

const std::string TrueSort(std::string str, bool(*comparator)(const std::string&
rhs, const std::string& lhs))
{
    std::stringstream ss(str);
    std::vector<std::string> vstr(std::istream_iterator<std::string>(ss), {});
    std::sort(vstr.begin(), vstr.end(), comparator);
    ss.clear();
    std::copy(vstr.begin(), vstr.end(), std::ostream_iterator<std::string>(ss, " "));
    return ss.str();
}

int main()
{
    std::string first  = "position total 12345 2jz asd512fgh";
    std::string second = "year 10010 2018r r98k hello";
    std::cout << TrueSort(first,  DigitFirst ) << std::endl;
    std::cout << TrueSort(second, LetterFirst);
}
ПОКАЗАТЬ ОТВЕТЫ
Другие вопросы по теме Информатика