Форум программистов, компьютерный форум CyberForum.ru

[STL] Работа со std::string - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Структура о веществе и сортировка http://www.cyberforum.ru/cpp-beginners/thread642077.html
Пишу структуру, описывающую информацию о веществе: название, удельный вес и проводимость(проводник, полупроводник, изолятор). Написать функции ввода и вывода; для сортировки данных по любому из признаков. Сделала с меню. Знаю что ошибка в выводе, при ее исправлении не работает. Также не могу разобраться с сортировкой, пыталась написать сортировку по весу. //main #include <stdio.h>...
C++ Наследование абстрактного класса, компилятор достал материться Уже весь мозг сломал, не понимаю, почему компилятор начинает ругаться. Есть абстрактный базовый класс в отдельном хедере: #pragma once class Shape { public: /*virtual double Dist(const Shape&) = 0; //1. */ virtual void Read() = 0; virtual void Move(int delta_x, int delta_y) = 0; http://www.cyberforum.ru/cpp-beginners/thread642072.html
C++ "Первый после Hello, world!". Программа решения квадратного уравнения
Добрый день, уважаемые форумчане. Покритикуйте пожалуйста, программу вывода на экран в полиномиальной форме и нахождения корней квадратного уравнения. Особые проблемы, собственно, возникли с первой частью - над тем, как вывести на экран полином, отвечающий при любых введенных коэффициентах всем правилам математики, пришлось немало поломать голову. Результаты таковы: class poly_part //class...
C++ Классы наследники
Всем привет, прошу помочь разобраться с ошибкой: 1>e:\my programs for c++\lesson 9 numb 9\lesson 9 numb 9\main.cpp(59) : error C2661: publication2::publication2: нет перегруженной функции, принимающей 3 аргументов 1>e:\my programs for c++\lesson 9 numb 9\lesson 9 numb 9\main.cpp(79) : error C2661: publication2::publication2: нет перегруженной функции, принимающей 3 аргументов вот код С++...
C++ Приведение LPVOID к классу "непостоянной" величины http://www.cyberforum.ru/cpp-beginners/thread642016.html
В поток посылаю экземпляр класс : userThread = CreateThread(NULL, NULL, ConnectionShell, (LPVOID)(&userCurrent), NULL, NULL); Где пытаюсь излвечь экземпляр : DWORD CALLBACK ConnectionShell(LPVOID lParam) { USER* userCurrent = new USER; memcpy(userCurrent, lParam, 44); // 44 - размер экземпляра после вызова стандартного\ конструктора userCurrent->Connection(); // Здесь так же побывали...
C++ В чём разница между total = total + trans и total += trans? Добрый день. Изучаю четвертое издание Липпмана. Автор задает вопрос: "В программе книжного магазина, при суммировании объектов trans и total, использован обычный оператор плюс, а не составной оператор суммы с присвоением. Почему не использован составной оператор?". Насколько мне известно а += b идентично a = a + b. Единственные догадки по этому поводу в том, что составной оператор суммы не... подробнее

Показать сообщение отдельно
OhMyGodSoLong
~ Эврика! ~
1243 / 992 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
27.08.2012, 15:59     [STL] Работа со std::string
Цитата Сообщение от vendeme Посмотреть сообщение
Не в тему, но и новый топик ради такого мини вопроса создавать не решил.
Можно ли более грамотно(STL) реализовать сам алгоритм замены числа?
Сделайте std::map<int, int>, хранящий нужные вам замены:
C++
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
27
28
29
30
31
32
33
34
35
36
37
38
#include <map>
#include <iostream>
 
void print(int array[], size_t size)
{
  for (size_t i = 0; i < size; ++i) {
    std::cout << array[i] << " ";
  }
  std::cout << std::endl;
}
 
void subst(const std::map<int, int> &func, int array[], size_t size)
{
  for (size_t i = 0; i < size; ++i) {
    auto found = func.find(array[i]);
    if (!(found == func.end())) {
      array[i] = found->second;
    }
  }
}
 
int main()
{
  int array[11] = { 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20 };
  std::map<int, int> changes = { {10, 1523},
                                 {11, 4123},
                                 {12, 125 },
                                 {13, 5531},
                                 {14, 5316},
                                 {15, 4423},
                                 {16, 6123},
                                 {17, 6341},
                                 {18, 6259},
                                 {19, 5241} };
  print(array, 11);
  subst(changes, array, 11);
  print(array, 11);
}
Вариант для STL-нутых на всю голову.
C++
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#include <map>
#include <iostream>
#include <algorithm>
 
template <class T>
struct Printer {
  void operator()(const T &element)
  {
    std::cout << element << " ";
  }
};
 
template <class T>
class Substitutor {
  const std::map<T, T> &theMap;
public:
  Substitutor(const std::map<T,T> &theMap_) : theMap(theMap_) {}
  
  void operator()(T &element)
  {
    auto found = theMap.find(element);
    if (!(found == theMap.end())) {
      element = found->second;
    }
  }
};
 
int main()
{
  int array[11] = { 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20 };
  std::map<int, int> changes = { {10, 1523},
                                 {11, 4123},
                                 {12, 125 },
                                 {13, 5531},
                                 {14, 5316},
                                 {15, 4423},
                                 {16, 6123},
                                 {17, 6341},
                                 {18, 6259},
                                 {19, 5241} };
  std::for_each(array, array + 11, Printer<int>());
  std::cout << std::endl;
  
  std::for_each(array, array + 11, Substitutor<int>(changes));
  
  std::for_each(array, array + 11, Printer<int>());
  std::cout << std::endl;
}

И для утят
C++
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
27
28
29
30
#include <map>
#include <iostream>
#include <algorithm>
 
int main()
{
  int array[11] = { 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20 };
  std::map<int, int> changes = { {10, 1523},
                                 {11, 4123},
                                 {12, 125 },
                                 {13, 5531},
                                 {14, 5316},
                                 {15, 4423},
                                 {16, 6123},
                                 {17, 6341},
                                 {18, 6259},
                                 {19, 5241} };
  std::for_each(array, array + 11, [] (int value) { std::cout << value << " "; });
  std::cout << std::endl;
  
  std::for_each(array, array + 11, [&] (int &value) {
                                     auto found = changes.find(value);
                                     if (!(found == changes.end())) {
                                       value = found->second;
                                     }
                                   });
  
  std::for_each(array, array + 11, [] (int value) { std::cout << value << " "; });
  std::cout << std::endl;
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru