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

Посимвольное сравнение

18.02.2012, 22:07. Показов 7779. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Не могу понять что я делаю не так, объясните пожалуйста.

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
49
50
51
52
53
54
55
56
#include <iostream>
#include <string>
using namespace std;
 
void main()
{
    char q1[30], q2[30];
    int r1, r2;
 
    cin.sync();
    cin.getline(q1, sizeof(q1), '\n');
    cin.sync();
    cin.getline(q2, sizeof(q2), '\n');
    cin.sync();
 
    for (int i=0; i<30; i++)
    {
        if (q1[i]==0)
        {
            r1=i;
            i=30;
        }
    }
    //cout<<r1<<endl; //Длинна первого слова
    for (int i=0; i<30; i++)
    {
        if (q2[i]==0)
        {
            r2=i;
            i=30;
        }
    }
    //cout<<r2<<endl; //Длинна второго слова
 
    for (int i=0; i<r1; i++)
    {
        for (int j=0; j<r2; j++)
        {
            char tmp1, tmp2;
            tmp1=q1[i];
            tmp2=q2[j];     
            cout<<"tmp1:"<<tmp1<<"   "<<"tmp2:"<<tmp2<<endl; //Значения выдаются правильно
 
            //Мне нужно сравнить q1[i] с q2[j], но просто вот так: strcmp(q1[i], q2[j]), не работает.
            //Не знаю правильно я поставил знак & или нет, но вроде должно работать.
            if (strcmp(&q1[i], &q2[j]));
                cout<<"q1[i] i q2[j]"<<endl;
            //Вот пробовал еще таким макаром сравнивать, через временные переменные, но та же фигня.
            if (strcmp(&tmp1, &tmp2));
                cout<<"tmp1 i tmp2"<<endl;
 
 
        }
    }
 
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.02.2012, 22:07
Ответы с готовыми решениями:

Как организовать посимвольное сравнение?
В ATL Object передаются две строки BSTR Сможет ли кто-нибудь реально показать, как организовать посимвольное сравнение? В доступной мне...

Посимвольное сравнение двух строк
Здравствуйте, уважаемые форумчане! Уже совсем голова не варит. Подскажите как правильно сравнить посимвольно (знаю, что можно просто...

Посимвольное сравнение строк из текстового файла
В общем, есть такое задание такое задание. &quot;В каждой строке текстового файла записаны фамилия, имя и отчество некоторого человека и его...

11
 Аватар для R136a1
143 / 112 / 36
Регистрация: 14.04.2011
Сообщений: 261
18.02.2012, 22:21
C++
1
#include <cstring>
Добавлено через 2 минуты
C++
1
2
3
4
5
int main()
{
...
return 0;
}
if(!strcmp(...))
1
3 / 3 / 0
Регистрация: 06.09.2011
Сообщений: 47
18.02.2012, 22:39  [ТС]
Цитата Сообщение от R136a1 Посмотреть сообщение
C++
1
#include <cstring>
Добавлено через 2 минуты
C++
1
2
3
4
5
int main()
{
...
return 0;
}
if(!strcmp(...))
Это был ответ на вопрос? или что?
1
277 / 150 / 25
Регистрация: 05.11.2011
Сообщений: 429
Записей в блоге: 1
18.02.2012, 22:58
Цитата Сообщение от Alexpm Посмотреть сообщение
Это был ответ на вопрос? или что?

Не по теме:

А был вопрос?

0
 Аватар для R136a1
143 / 112 / 36
Регистрация: 14.04.2011
Сообщений: 261
18.02.2012, 23:06
Цитата Сообщение от Alexpm Посмотреть сообщение
Это был ответ на вопрос? или что?
да.
strcmp обитает в cstring или string.h
если строки равны, то strcmp возвращает 0, поэтому if(!strcmp) (если хотите узнать какая больше, какая меньше - strcmp)
int main {... return 0;} более правильная конструкция
0
3 / 3 / 0
Регистрация: 06.09.2011
Сообщений: 47
19.02.2012, 10:25  [ТС]
Цитата Сообщение от R136a1 Посмотреть сообщение
да.
strcmp обитает в cstring или string.h
если строки равны, то strcmp возвращает 0, поэтому if(!strcmp) (если хотите узнать какая больше, какая меньше - strcmp)
int main {... return 0;} более правильная конструкция
А вы смотрели приложенный код? видели что имелось ввиду под "посимвольным сравнением"? и что требуется сделать? Если нет, то посмотрите еще раз.
А я тут повторю, мне нужно сравнивать q1[i] с q2[j], т.е. сравнивать не слова целиком, а сравнивать посимвольно. Для того, чтобы найти повторяющиеся символы в обоих словах.
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
19.02.2012, 10:41
Цитата Сообщение от Alexpm Посмотреть сообщение
т.е. сравнивать не слова целиком, а сравнивать посимвольно
Однако, для сравнения используешь функцию сравнения строк. Молодец.

Цитата Сообщение от Alexpm Посмотреть сообщение
Не знаю правильно я поставил знак & или нет, но вроде должно работать.
Это не Basic. Не нужно делать то, чего ты не понимаешь. Сперва прочитай про операторы языка Си, а не тыкай разные кнопочки наугад...
0
3 / 3 / 0
Регистрация: 06.09.2011
Сообщений: 47
19.02.2012, 11:00  [ТС]
Цитата Сообщение от Deviaphan Посмотреть сообщение
Однако, для сравнения используешь функцию сравнения строк. Молодец.
Не думал что есть разница в сравнении одного символа или строки.
Цитата Сообщение от Deviaphan Посмотреть сообщение
Не нужно делать то, чего ты не понимаешь.
Если у меня что то не получается, то я пробую изменить как то иначе. Метод проб и ошибок довольно часто помогает, в конечном итоге начинаешь понимать что было не так.
Пробовал сравнивать просто q1[i]==q2[j], но результат тот же.. понятия не имею как можно еще..
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
19.02.2012, 11:14
Цитата Сообщение от Alexpm Посмотреть сообщение
в конечном итоге начинаешь понимать что было не так
В конечном итоге будет каша в голове - только и всего. В С++ надо чётко понимать, что ты делаешь, иначе беда будет на каждом шагу.
0
3 / 3 / 0
Регистрация: 06.09.2011
Сообщений: 47
19.02.2012, 11:17  [ТС]
Цитата Сообщение от silent_1991 Посмотреть сообщение
В конечном итоге будет каша в голове - только и всего. В С++ надо чётко понимать, что ты делаешь, иначе беда будет на каждом шагу.
Не знаю каша или нет, но вопрос снимается)) понял как надо было делать и в чём была ошибка..

Вначале я пробовал сравнивать просто q1[i]==q2[j], у меня не получилось и я начал пробовать как в первом посте.. А ошибка была в опечатке (точка с запятой после if (); была). Вот так вот..
0
0 / 0 / 0
Регистрация: 18.02.2012
Сообщений: 4
19.02.2012, 11:17
Цитата Сообщение от Alexpm Посмотреть сообщение
Пробовал сравнивать просто q1[i]==q2[j], но результат тот же.. понятия не имею как можно еще..
может тебе нужно сравнить
C++
1
 q1[i]==q2[i]
?
0
3 / 3 / 0
Регистрация: 06.09.2011
Сообщений: 47
19.02.2012, 11:23  [ТС]
Цитата Сообщение от МаксС Посмотреть сообщение
может тебе нужно сравнить
C++
1
 q1[i]==q2[i]
?
Нет, в предыдущем посте все написанно.
Вопрос снимается.
ps:
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
#include <iostream>
#include <string>
 
using namespace std;
 
void main()
{
    char q1[30], q2[30];
    int r1, r2;
 
    cin.sync();
    cin.getline(q1, sizeof(q1), '\n');
    cin.sync();
    cin.getline(q2, sizeof(q2), '\n');
    cin.sync();
 
    for (int i=0; i<30; i++)
    {
        if (q1[i]==0)
        {
            r1=i;
            i=30;
        }
    }
    //cout<<r1<<endl; //Длинна первого слова
    for (int i=0; i<30; i++)
    {
        if (q2[i]==0)
        {
            r2=i;
            i=30;
        }
    }
    //cout<<r2<<endl; //Длинна второго слова
 
    for (int i=0; i<r1; i++)
    {
        for (int j=0; j<r2; j++)
        {
            if (q1[i]==q2[j])
                cout<<"q1[i] i q2[j]"<<endl;
        }
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.02.2012, 11:23
Помогаю со студенческими работами здесь

посимвольное переписывание
Есть name1(фамилия), name2 и name3 (инициалы вида &quot;X.&quot;, где X - первая буква имени/отчества). Нужно переписать это все в renter.name_man и...

посимвольное считывание
У меня есть переменная типа string которая равна &quot;000000000000&quot;. Мне нужно программно превратить ее вот в такую: 000-000-000-000. Я хочу...

Посимвольное краска
Народ подскажите пожалуйста как посимвольное красить буквы? например в слове Привет, сделать разным каждые буквы по цвету

Посимвольное чтение
В консоль подается текст содержащий такие выражения: а=3 b=7 z=32 a=1 y=2 b=7 &quot;EOF&quot;-конец. программа не...

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


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru