(C ++) Замена любого значения массива, найденного в строке, соответствующими значениями другого массива?

Я перепробовал разные вещи. К сожалению, я не храню предыдущие записи кода, поэтому я просто покажу вам, что у меня есть:

    string l2n(std::string input) {
std::string original[26] = {"A","B","C","D","E", "F", "G", "H", "I", "J", "K," "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"};
//std::string originalLower[26] = {"a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"};
std::string newval[26] = {"1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19", "20", "21", "22", "23", "24", "25", "26"};
string neworig = (original[0], original[1], original[2], original[3], original[4], original[5], original[6], original[7], original[8], original[9], original[10], original[11], original[12], original[13], original[14], original[15], original[16], original[17], original[18], original[19], original[20], original[21], original[22], original[23], original[24], original[25]);
string newnewval = (newval[0], newval[1], newval[2], newval[3], newval[4], newval[5], newval[6], newval[7], newval[8], newval[9], newval[10], newval[11], newval[12], newval[13], newval[14], newval[15], newval[16], newval[17], newval[18], newval[19], newval[20], newval[21], newval[22], newval[23], newval[24], newval[25]);
size_t posit = input.find(neworig.c_str());
string hash2345;
hash2345 = input.replace(posit, std::string(neworig).length(), newnewval.c_str());
return hash2345;
}

Это прекрасно компилируется, но выводит «26HELLO» с моим вводом «HELLO». Он буквально добавляет 26 к началу любого входного сигнала. Я предполагаю, что это как-то связано с использованием input.replace с использованием длины, но я не знаю, что еще делать, и Google не находит что-нибудь.
Спасибо за вашу помощь!

0

Решение

Я думаю, что вы неправильно понимаете, что string::replace делает. Он не заменяет символы в одной строке эквивалентно расположенными символами в другой. Он заменяет диапазон символов в одной строке на всю другую строку.

Например,

std::string test = "This is a test.";

// Replace 2 characters, starting at position 5 with "was"test.replace(5, 2, "was");

std::cout << test;  // Outputs "This was a test."

Для того, что вы делаете, вам понадобится цикл, который выполняет действие для каждого символа в вашем вводе, например,

string hash2345;

// For each character in input
for (int i = 0; i < input.length(); ++i) {

// Try to find the string equal to the i'th character of input in
// the "original" array.
string* original_val_ptr = std::find(original, original + 26,
std::string(input[i]));

// Make sure that it actually found something (this handles the case
// where input has some other characters, like lowercase or punctuation).
if (original_val_ptr != NULL) {

// Find the position of this value in the original array.
size_t pos = original_val_ptr - original;

// Add the string in the equivalent position in the "newval" array
// to the output.
hash2345 += newval[pos];
}
}

return hash2345;

Теперь есть ряд дополнительных улучшений, которые могут быть внесены в ваш код, и я уверен, что другие ответы будут предлагать их, но, учитывая, что вы кажетесь относительно новым программистом, я предпочитаю оставить этот ответ таким же простым, как возможно и сосредоточиться только на правильности алгоритма, который вы, очевидно, пытаетесь реализовать.

Кроме того, это будет работать для любого сопоставления одного набора символов другому, даже если это не буквы в числах.

1

Другие решения

Основываясь на комментариях выше и предполагая, что вы используете ASCII, то следующее делает то, что вы хотите

string l2n(std::string input)
{
ostringstream buf;
for (string::const_iterator i = input.begin(); i != input.end() ++i)
{
buf << (*i - 'A') + 1;
}
return buf.str();
}
0

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector