Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
0 / 0 / 1
Регистрация: 06.03.2012
Сообщений: 29

cannot convert parameter 1 from 'int' to 'std::string &'

14.04.2012, 22:02. Показов 2423. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
C++
1
2
3
4
5
6
7
string kolvo(string &S, int &k)
{
    unsigned int i;
    for(i=1; i<S.length(); i++)
        if(S[i]=='B' && S[i-1]==' ')
            k=k+1;
}
kolvo(S,k);
Что не так делаю?
Можно ли в стринг использовать инт?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.04.2012, 22:02
Ответы с готовыми решениями:

Странная ошибка: [Error] no match for call to '(std::string {aka std::basic_string<char>}) (int&)'
У меня появляется проблема при компиляции сей программы: #include &lt;iostream&gt; #include &lt;string&gt; #include &lt;sstream&gt; ...

ошибка error: cannot convert 'std::string {aka std::basic_string<char>}' to 'std::string* {aka std::basic_stri
на вод поступают 2 строки типа string. определить количество вхождений строки 2 в строку 1 ошибка error: cannot convert 'std::string {aka...

Ошибки: Cannot implicitly convert type 'string' to 'int' и Argument 1: cannot convert from 'int' to 'string'
youtube.com_Пишем парсер на Csharp. Ошибка Пытаюсь написать парсер. Вроде сделал всё как в уроке. Выдаёт ошибки: - в строке...

13
 Аватар для Toshkarik
1181 / 894 / 94
Регистрация: 03.08.2011
Сообщений: 2,461
14.04.2012, 22:14
Ну во первых, если вы не возвращаете из функции значение, то измените его на void. Во вторых - что эта функция должна делать? Преобразовать число в строку? Тогда вам нужна функция itoa.
1
0 / 0 / 1
Регистрация: 06.03.2012
Сообщений: 29
14.04.2012, 22:18  [ТС]
Цитата Сообщение от Toshkarik Посмотреть сообщение
Ну во первых, если вы не возвращаете из функции значение, то измените его на void. Во вторых - что эта функция должна делать? Преобразовать число в строку? Тогда вам нужна функция itoa.
Это функция поиска и подсчета кол-ва начальной буквы в строке
0
 Аватар для Toshkarik
1181 / 894 / 94
Регистрация: 03.08.2011
Сообщений: 2,461
14.04.2012, 22:36
Тогда луче пусть она возвращает число этих букв, а в качестве параметров имеет строку и необходимую букву.
Вот пример:
C++
1
2
3
4
5
6
7
8
9
10
11
12
std::size_t counts( const std::string &str, const char c ) {
   std::size_t count = 0;
 
   if ( str[ 0 ] == c )
      count = 1;
 
   for ( std::size_t i = 1; i < str.length(); i++ )
      if ( str[ i ] == c && str[ i - 1 ] == ' ' )
         count++;
 
   return count;
}
1
0 / 0 / 1
Регистрация: 06.03.2012
Сообщений: 29
14.04.2012, 22:38  [ТС]
Цитата Сообщение от Toshkarik Посмотреть сообщение
Тогда луче пусть она возвращает число этих букв, а в качестве параметров имеет строку и необходимую букву.
Вот пример:
C++
1
2
3
4
5
6
7
8
9
10
11
12
std::size_t counts( const std::string &str, const char c ) {
   std::size_t count = 0;
 
   if ( str[ 0 ] == c )
      count = 1;
 
   for ( std::size_t i = 1; i < str.length(); i++ )
      if ( str[ i ] == c && str[ i - 1 ] == ' ' )
         count++;
 
   return count;
}
Хорошо, но все таки я не пойму, почему моя программа не прокатывает, что я делаю не так? Не могу успокоиться.
0
 Аватар для Toshkarik
1181 / 894 / 94
Регистрация: 03.08.2011
Сообщений: 2,461
14.04.2012, 22:40
Вы неправильно вызываете функцию, покажите ее вызов.
1
0 / 0 / 1
Регистрация: 06.03.2012
Сообщений: 29
14.04.2012, 22:42  [ТС]
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<iostream>
#include<string.h>
#include<string>
using namespace std;
string vvod()
{
    char S[80];
    gets(S);
    return string (S);
 
}
void poisk(string &S, int &k)
{
    unsigned int i;
    for(i=1; i<S.length(); i++)
        if(S[i]=='B' && S[i-1]==' ')
            k=k+1;
}
int main()
{
    setlocale(0,"russian");
    system ("color 70");
    
    int S,S1,str,k=0;
    vvod();
    poisk(S,k);
    cout<<"Количество букв B"<<k<<endl;
    system ("pause");
    return 0;
}
Кусками программу показывать нет смысла. Вот.
0
DU
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
14.04.2012, 22:45
int S,S1,str,k=0;
vvod();
poisk(S,k);

переменная S имеет тип int, а функция poisk требует, чтобы первым агрументом была ссылка на строку. инт не может бысть преобразован в ссылку на строку.

исправте на
C++
1
2
3
string str = vvod();
int k = 0;
poisk(str, k);
1
 Аватар для Toshkarik
1181 / 894 / 94
Регистрация: 03.08.2011
Сообщений: 2,461
14.04.2012, 22:48
Вы определяете переменную S как int и пытаетесь передать ее в функцию как строку. У вас все неправильно. Функция vvod создает массив, вводит его, и возвращает. Только куда возвращает? Вы ее ни чему не присваиваете. И пользуйтесь пожалуйста тегами форматирования кода, читать очень сложно.
1
0 / 0 / 1
Регистрация: 06.03.2012
Сообщений: 29
14.04.2012, 22:52  [ТС]
Цитата Сообщение от DU Посмотреть сообщение
int S,S1,str,k=0;
vvod();
poisk(S,k);

переменная S имеет тип int, а функция poisk требует, чтобы первым агрументом была ссылка на строку. инт не может бысть преобразован в ссылку на строку.
Емае проглядел. Огромное спасибО!

Добавлено через 3 минуты
Цитата Сообщение от Toshkarik Посмотреть сообщение
Вы определяете переменную S как int и пытаетесь передать ее в функцию как строку. У вас все неправильно. Функция vvod создает массив, вводит его, и возвращает. Только куда возвращает? Вы ее ни чему не присваиваете. И пользуйтесь пожалуйста тегами форматирования кода, читать очень сложно.
Я только учусь, поэтому сижу в разделе "для начинающих".
0
 Аватар для Toshkarik
1181 / 894 / 94
Регистрация: 03.08.2011
Сообщений: 2,461
14.04.2012, 22:52
Думаю, что нужно было что то вроде этого:
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
#include<iostream>
#include<string.h>
#include<string>
using namespace std;
 
string vvod( ) {
   string strTemp;
 
   getline( cin, strTemp );
 
   return strTemp;
}
 
void poisk( string &S, int &k ) {
   unsigned int i;
   for ( i = 1; i < S.length( ); i++ )
      if ( S[i] == 'B' && S[i - 1] == ' ' )
         k = k + 1;
}
 
int main( ) {
   setlocale( 0, "russian" );
   system( "color 70" );
 
   string str = vvod();
   int  k = 0;
   
   poisk( str, k );
   cout << "Количество букв B" << k << endl;
   system( "pause" );
   return 0;
}
1
0 / 0 / 1
Регистрация: 06.03.2012
Сообщений: 29
14.04.2012, 22:54  [ТС]
Цитата Сообщение от DU Посмотреть сообщение
int S,S1,str,k=0;
vvod();
poisk(S,k);

переменная S имеет тип int, а функция poisk требует, чтобы первым агрументом была ссылка на строку. инт не может бысть преобразован в ссылку на строку.

исправте на
C++
1
2
3
string str = vvod();
int k = 0;
poisk(str, k);
Еще раз спасибо, уже все исправил!
От Души!

Добавлено через 47 секунд
Цитата Сообщение от Toshkarik Посмотреть сообщение
Думаю, что нужно было что то вроде этого:
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
#include<iostream>
#include<string.h>
#include<string>
using namespace std;
 
string vvod( ) {
   string strTemp;
 
   getline( cin, strTemp );
 
   return strTemp;
}
 
void poisk( string &S, int &k ) {
   unsigned int i;
   for ( i = 1; i < S.length( ); i++ )
      if ( S[i] == 'B' && S[i - 1] == ' ' )
         k = k + 1;
}
 
int main( ) {
   setlocale( 0, "russian" );
   system( "color 70" );
 
   string str = vvod();
   int  k = 0;
   
   poisk( str, k );
   cout << "Количество букв B" << k << endl;
   system( "pause" );
   return 0;
}
Угу, сделал.

Добавлено через 52 секунды
Только вот проблема, если первым символом написать Б, то он ее не читает. Как исправить ситуацию?
0
 Аватар для Toshkarik
1181 / 894 / 94
Регистрация: 03.08.2011
Сообщений: 2,461
14.04.2012, 22:58
Так вы ведь начинаете цикл в функции poisk с 1, а индексация в С++ идет с 0. Но если вы начнете с 0, то произойдет выход за пределы массива при проверке условия
C++
1
if ( S[i] == 'B' && S[i - 1] == ' ' )
так как при i == 0, индекс будет отрицательным. Предлагаю сделать как я писал на предыдущей странице, то есть просто поставьте перед циклом проверку
C++
1
2
if ( S[ 0 ] == 'B' )
   k=k+1;
и пусть цикл так же и начинается с 1.
1
0 / 0 / 1
Регистрация: 06.03.2012
Сообщений: 29
14.04.2012, 23:02  [ТС]
Цитата Сообщение от Toshkarik Посмотреть сообщение
Так вы ведь начинаете цикл в функции poisk с 1, а индексация в С++ идет с 0. Но если вы начнете с 0, то произойдет выход за пределы массива при проверке условия
C++
1
if ( S[i] == 'B' && S[i - 1] == ' ' )
так как при i == 0, индекс будет отрицательным. Предлагаю сделать как я писал на предыдущей странице, то есть просто поставьте перед циклом проверку
C++
1
2
if ( S[ 0 ] == 'B' )
   k=k+1;
и пусть цикл так же и начинается с 1.
Все спасибо большое, побольше бы таких отзывчивых пользователей.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.04.2012, 23:02
Помогаю со студенческими работами здесь

Выделение памяти для буффера, под std::istream& operator>>(std::istream &, String &)
Добрый день. Как осуществляется выделения памяти под перегруженный оператор ввода данных в пользовательский тип? Ведь мы заранее не можем...

Ошибка: 'fputc' : cannot convert parameter 1 from 'char *' to 'int'
Помогите разобраться Я начинающий программист, не судите строго:- int _tmain() { char *a; a=&quot;TTTT+&quot;; FILE *fp; ...

Std::string and std::wstring convert
случайно наткнулся на такую вот конвертацию std::string в std::wstring std::string text(&quot;text&quot;); ...

error C2664: cannot convert parameter 1 from 'TButton' to 'const TDeque &'
Добрый день. Ошибка написана вверху. Вот собственно код: // cоздаем дек с единственным элементом TDeque(TControl *d):Head(new...

На основе исходного std::vector<std::string> содержащего числа, создать std::vector<int> с этими же числами
подскажите есть вот такая задача. Есть список . Создать второй список, в котором будут все эти же числа, но не в виде строк, а в виде...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! в-строка - входное арифметическое выражение в инфиксной(обычной). . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru