0 / 0 / 0
Регистрация: 01.03.2013
Сообщений: 58

Сравнение строк

16.12.2014, 11:11. Показов 1582. Ответов 6
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Есть два файла,достаю из первого - 1-ю строку и из 2 - 1-ю строку
Они имеют вид:
1;bla;3412;sha;1234;4321;28.15;

3;alb;1243;ash;1234;4321;28.02


Нужно сравнить их по одинаковому элементу строки и в новый файл записать общее то что получилось:
1;3;bla;alb;3412;1241;sha;ash;1234;4321; 28.15;28.02


Прошу помочь написать функции сравнения
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.12.2014, 11:11
Ответы с готовыми решениями:

Сравнение строк
char hey ; // оператор для выбора cout << "Как мне к вам обращаться? На ты или вы? (введите 'ты', либо 'вы'): " << endl; ...

Сравнение строк
У меня передаётся параметр при запуске через командную строку *argv, и сравнивается с уже заданным *char; Вот сам код: #include...

Сравнение строк
Сначала указываю каталог, из которого нужно вывести список файлов этого каталога, затем ввожу имя искомого файла. В цикле делаю сравнение...

6
7803 / 6567 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
16.12.2014, 11:24
Нужно извлекать не строку целиком, а отдельные составляющие, и после их сравнивать. Используй, например, getline() c delimeter = ';'.
0
0 / 0 / 0
Регистрация: 01.03.2013
Сообщений: 58
16.12.2014, 11:31  [ТС]
а можно пример,самый примитивный
0
173 / 131 / 74
Регистрация: 04.12.2013
Сообщений: 552
16.12.2014, 12:15
Лучший ответ Сообщение было отмечено ebywku как решение

Решение

секунду

Добавлено через 4 минуты
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
string check(string s1, string s2) {
    string result = "";
    string delim = ";";
    
    unsigned long index = s1.find(delim);
    while (1) {
        string sub1 = s1.substr(0, index);
        string sub2 = s2.substr(0, index);
        if (index == s1.length() - 1) {
            result += sub1 + ";" + sub2 + ";";
            break;
        }
        if (sub1 == sub2) {
            result += sub1 + ";";
        } else {
            result += sub1 + ";" + sub2 + ";";
        }
        s1.erase(0, index + 1);
        s2.erase(0, index + 1);
    
        index = s1.find(delim);
    }
    
    
    return result;
}
1
0 / 0 / 0
Регистрация: 01.03.2013
Сообщений: 58
16.12.2014, 12:34  [ТС]
E2467 'stringcheck(string,string)' cannot return a value
убрал,запустил, но итог не утешил, бесконечный набор цифр,может что то не так сделал?

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
#include <string>
#include <fstream>
#include <iostream>
using namespace std;
 
 
void stringcheck(string s1, string s2) {
    string result = "";
    string delim = ";";
 
    unsigned long index = s1.find(delim);
    while (1) {
        string sub1 = s1.substr(0, index);
        string sub2 = s2.substr(0, index);
        if (index == s1.length() - 1) {
            result += sub1 + ";" + sub2 + ";";
            break;
        }
        if (sub1 == sub2) {
            result += sub1 + ";";
        } else {
            result += sub1 + ";" + sub2 + ";";
        }
        s1.erase(0, index + 1);
        s2.erase(0, index + 1);
 
        index = s1.find(delim);
 
    }
 
  return result ;
 
}
 
int main()
{
 string s1="21321;231312;211;11;1;1",s2="21231;211212;12121;33";
stringcheck(s1,s2);
 
system("pause");
}
0
173 / 131 / 74
Регистрация: 04.12.2013
Сообщений: 552
16.12.2014, 14:14
Лучший ответ Сообщение было отмечено ebywku как решение

Решение

ebywku, потому что моя программа сравнивает строки одинаковой длины и одинаковой структуры. Вы не уточняли, что могут быть строки разной длины и т.п.. Можете сами переписать, или подождите до вечера.
1
0 / 0 / 0
Регистрация: 01.03.2013
Сообщений: 58
16.12.2014, 14:22  [ТС]
сейчас попробую сам,а вечером с вашим результатом сверюсь,если вы не против
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.12.2014, 14:22
Помогаю со студенческими работами здесь

Сравнение строк
Написал элементарную функцию, проверяющую введённый пользователем текст. Проблема в том, что он в любом случае выдаёт &quot;Ввод не удался....

сравнение строк
Нужно сравнить строки типа стринг, без использования стандартных функций НЕ знаю,как их присвоить, пытаюсь передать функции string11 b...

Сравнение строк
Всем привет, имеется строка записаная в масив, как мне сравнить первую букву єтой строки с єтой строкой. Я понимаю что нужно записать...

Сравнение 2 строк
сравнивать строки я умею тут вопрос немного в другом. по какому принципу определяет что ab больше ba все мы канешно понимаем алфавит и...

Сравнение строк
Тупо и банально нужно сравнить строки средствами с++. Гуглил, но не нашел работающих примеров, толи руки из одного места.. Как сравнивать...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

Новые блоги и статьи
MVC фреймворк в PHP
Jason-Webb 19.04.2025
Архитектурный паттерн Model-View-Controller (MVC) – это не просто модный термин из мира веб-разработки. Для PHP-программистов это фундаментальный подход к организации кода, который радикально меняет. . .
Dictionary Comprehensions в Python
py-thonny 19.04.2025
Python славится своей выразительностью и лаконичностью, что позволяет писать чистый и понятный код. Среди множества синтаксических конструкций языка особое место занимают словарные включения. . .
Шаблоны и протоколы для создания устойчивых микросервисов
ArchitectMsa 19.04.2025
Микросервисы — архитектурный подход, разбивающий сложные приложения на небольшие, независимые компоненты. Вместо монолитного гиганта, система превращается в созвездие небольших взаимодействующих. . .
Изменяемые и неизменяемые типы в Python
py-thonny 19.04.2025
Python славится своей гибкостью и интуитивной понятностью, а одна из главных его особенностей — это система типов данных. В этом языке все, включая числа, строки, функции и даже классы, является. . .
Интеграция Hangfire с RabbitMQ в проектах C#.NET
stackOverflow 18.04.2025
Разработка современных . NET-приложений часто требует выполнения задач "за кулисами". Это может быть отправка email-уведомлений, генерация отчётов, обработка загруженных файлов или синхронизация. . .
Построение эффективных запросов в микросервисной архитектуре: Стратегии и практики
ArchitectMsa 18.04.2025
Микросервисная архитектура принесла с собой много преимуществ — возможность независимого масштабирования сервисов, технологическую гибкость и четкое разграничение ответственности. Но как часто бывает. . .
Префабы в Unity: Использование, хранение, управление
GameUnited 18.04.2025
Префабы — один из краеугольных элементов разработки игр в Unity, представляющий собой шаблоны объектов, которые можно многократно использовать в различных сценах. Они позволяют создавать составные. . .
RabbitMQ как шина данных в интеграционных решениях на C# (с MassTransit)
stackOverflow 18.04.2025
Современный бизнес опирается на множество специализированных программных систем, каждая из которых заточена под решение конкретных задач. CRM управляет отношениями с клиентами, ERP контролирует. . .
Типы в TypeScript
run.dev 18.04.2025
TypeScript представляет собой мощное расширение JavaScript, которое добавляет статическую типизацию в этот динамический язык. В JavaScript, где переменная может свободно менять тип в процессе. . .
Погружение в Kafka: Концепции и примеры на C# с ASP.NET Core
stackOverflow 18.04.2025
Apache Kafka изменила подход к обработке данных в распределенных системах. Эта платформа потоковой передачи данных выходит далеко за рамки обычной шины сообщений, предлагая мощные возможности,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru