Форум программистов, компьютерный форум, киберфорум
C/С++ под Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 25.04.2013
Сообщений: 9

Определить все символы, содержащиеся как в строке S1, так и в строке S2

25.04.2013, 21:31. Показов 1989. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста решить задачи С++ под Linux

Определить все символы, содержащиеся как в строке S1, так и в строке S2. Входные данные первого приложения: строка символов S1 произвольной длины. Входные данные второго приложения: строка символов S2 произвольной длины.

Добавлено через 16 минут
Кто разбирается помогите пожалуйста!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.04.2013, 21:31
Ответы с готовыми решениями:

Удалить из первой строки все символы, содержащиеся во второй строке
Ввести 2 символьные строки. Удалить из первой строки все символы, содержащиеся во второй строке. Строки до и после преобразования вывести...

Удалить из первой строки все символы, содержащиеся во второй строке
Ввести две символьный строки. Удалить из первой строки все символы, содержащиеся во второй строке. Строки до и после преобразования вывести...

Удалить из первой строки все символы, содержащиеся во второй строке
Ввести 2 символьные строки. Удалить из первой строки все символы, содержащиеся во второй строке. Строки до и после преобразования вывести...

15
Антикодер
Эксперт функциональных языков программирования
1888 / 870 / 48
Регистрация: 15.09.2012
Сообщений: 3,088
30.04.2013, 13:18
Вам нужно для начала понять алгоритм сравнения этих строк, без C++ и Linux.
представим строки в виде двух массивов. Как вы будете искать одинаковые символы в этих массивах?
1
0 / 0 / 0
Регистрация: 25.04.2013
Сообщений: 9
30.04.2013, 19:21  [ТС]
Я только начал изучать С++. Вот поэтому написал, чтобы понять и разобраться. Но всё равно спасибо!!!
0
Антикодер
Эксперт функциональных языков программирования
1888 / 870 / 48
Регистрация: 15.09.2012
Сообщений: 3,088
30.04.2013, 21:13
так а причем здесь C++. вы возьмите математику и подумайте как сравнить два массива на наличие одинаковых элементов. Если поймете, останется только синтаксис C++ посмотреть.
1
0 / 0 / 0
Регистрация: 25.04.2013
Сообщений: 9
30.04.2013, 21:23  [ТС]
Хорошо. Спасибо.

Добавлено через 2 минуты
Мне надо было код написать этой задачи в С++ под Линукс, чтобы запустить в компиляторе.
0
Антикодер
Эксперт функциональных языков программирования
1888 / 870 / 48
Регистрация: 15.09.2012
Сообщений: 3,088
30.04.2013, 21:29
посмотрите какая прекрасная статья в вики есть Список_алгоритмов вам нужно только выбрать алгоритм.(правда там не только по вашей теме, но мне самому интересно стало алгоритмы посмотреть из этой статьи)

когда я учился столько полезной инфы не было.
1
0 / 0 / 0
Регистрация: 25.04.2013
Сообщений: 9
30.04.2013, 22:33  [ТС]
Спасибо вам большое!!!
0
Антикодер
Эксперт функциональных языков программирования
1888 / 870 / 48
Регистрация: 15.09.2012
Сообщений: 3,088
01.05.2013, 11:46
вот кстати что я нашёл в этом форуме Удаление всех символов строки s1, встречающихся в s2

практически решенная ваша задача
1
0 / 0 / 0
Регистрация: 25.04.2013
Сообщений: 9
01.05.2013, 22:27  [ТС]
Спасибо Вам большое за помощь, и за ссылку форума!!! Очень помогли!!!
0
Антикодер
Эксперт функциональных языков программирования
1888 / 870 / 48
Регистрация: 15.09.2012
Сообщений: 3,088
01.05.2013, 22:42
довайте возьмём всё самое лучшее из этой темы и попробуем придумать эффективный алгоритм
вот исходная программа для удаления совпадающий символов

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
using std::cout;
using std::cin;
void squeeze(char s1[], char s2[]){
    int k=0;
    for(int i=0,j;s1[i];i++){
        for(j=0;s2[j];j++)
            if(s2[j]==s1[i])
                break;
        if(!s2[j]) s1[k++]=s1[i];
    }
    s1[k]=0;
}
 
int main(){
    char s1[25],s2[25];
    cin>>s1>>s2;
    squeeze(s1,s2);
    cout<<s1;
    return 0;
}
отложим её пока в сторону и обсудим как мы будем искать символы
1
0 / 0 / 0
Регистрация: 25.04.2013
Сообщений: 9
01.05.2013, 23:44  [ТС]
Спасибо, попробую запустить на компиляторе! ББлагодарю!!!
0
Антикодер
Эксперт функциональных языков программирования
1888 / 870 / 48
Регистрация: 15.09.2012
Сообщений: 3,088
02.05.2013, 00:08
та довайте, например разобьём название этой темы на две части и сделаем из них два массива
Bash
1
2
3
4
5
a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10
О  п  р  е  д  е  л  и  т  ь 
второй массив
b0 b1 b2 b3 b4 b5 b6 b7 b8 b9 b10 b11
в  с  е     с  и  м  в  о  л  ы    ,
с чего нужно начать проверку? как думаете?
0
4 / 4 / 0
Регистрация: 08.11.2011
Сообщений: 137
01.06.2013, 12:51
XRuZzz, Взять а[0] и проверить в цикле каждый элемент массива b на равенство a[0]-ому. Так проверить каждый элемент а. ??
0
Антикодер
Эксперт функциональных языков программирования
1888 / 870 / 48
Регистрация: 15.09.2012
Сообщений: 3,088
01.06.2013, 14:55
ну да, ну и? Есть ещё варианты?
0
4 / 4 / 0
Регистрация: 08.11.2011
Сообщений: 137
01.06.2013, 15:46
XRuZzz,
C++ (Qt)
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
#include <sys/types.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <iostream>
using namespace std;  
 
void squeeze(char s1[], char s2[], char s3[]){
    int k=0, i,j;
    for(i=0;i<25;i++){
        for(j=0;j<25;j++)
            if(s2[j]==s1[i]){
        s3[k]=s2[j];
        k++;
                break;
    }
    }
 
}
 
int main(){
    printf("\n---<Символы, содержащиеся в двух строках>---\n");
    char s1[25],s2[25],s3[25];
    cin>>s1>>s2;
    squeeze(s1,s2,s3);
    cout<<s3<<"\n";
    exit(0);
}
1
127 / 131 / 11
Регистрация: 25.12.2011
Сообщений: 443
02.06.2013, 10:21
Вот же есть уже готовый метод у std::string.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.06.2013, 10:21
Помогаю со студенческими работами здесь

Вывести символы содержащие в строке s и p, но не содержащиеся в строке r
использовать тип данных множества. Вывести символы содержащие в строке s и p,но не содержащиеся в строке r.

Как вывести все цифры, содержащиеся в строке?
У меня задание такое - дана строка символов. Вывести на экран цифры, содержащиеся в строке. Вот что написал - private void...

Даны две строки.Выведите на экран все символы которые присутствуют как в первой так и во второй строке
Даны две строки.Выведите на экран все символы которые присутствуют как в первой так и во второй строке. Задача подразумевает полноценное...

Вывести символы строки s, но не содержащиеся в строке p
использовать тип данных множества. Вывести символы строки s,но не содержащие строке p.

Из множества символов первой строки удалить символы содержащиеся во второй строке
Народ, помогите пожалуйста :-С помощью одной/двух из этих процедур: -ввода с клавиатуры числового множества -ввода с клавиатуры...


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение/ Перевод https:/ / **********/ gallery/ thinkpad-x220-tablet-porn-gzoEAjs . . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru