Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.67/86: Рейтинг темы: голосов - 86, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 31.10.2014
Сообщений: 4

Как сравнить две строки?

31.10.2014, 22:11. Показов 18452. Ответов 21
Метки нет (Все метки)

Написал программу но не проходит сравнение вот это сравнение:
C++
1
2
3
4
5
 bool flight_weight(char* flight)
    {
        if (predmet==flight) return true;
        else return false;
    };
Может кто нибудь объяснить что я сделал не так?

Весь код программы:

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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
#pragma warning(disable : 4996)
#include "stdafx.h"
#include "clocale"
#include "string.h"
#include <iostream>
#include <stdlib.h>
using namespace std;
 
class groups
{
    int num;
    char* surname;
    char* predmet;
    double ball;
    friend void key_fill(groups&);
 
public:
    static int n;
 
    groups()
    {
        n++;
        num = 0;
        ball = 0;
        surname = NULL;
        predmet = NULL;
    };
 
    groups(groups& p)
    {
        n++;
        num = p.num;
        ball = p.ball;
        surname = new char [strlen(p.surname)+1];
        strcpy(surname, p.surname);
        predmet = new char [strlen(p.predmet)+1];
        strcpy(predmet, p.predmet);
    };
 
    void tab_display()
    {
        if (surname==NULL) printf ("Нет данных\n");
        else printf ("%d\t\t%s\t\t\t%.2f\t\t\t%s\n", num, surname, ball, predmet);
    };
 
    bool flight_weight(char* flight)
    {
        if (predmet==flight) return true;
        else return false;
    };
 
    bool is_higher_price(int pr)
    {
        if (ball<pr) return true;
        else return false;
    };
 
    ~groups()
    {
        n--;
        delete[] surname;
    };
};
 
void key_fill(groups& f)
{
    int key_num;
    double key_ball;
    char* key_surname;
    char* key_predmet;
    printf ("\nВведите данные о студенте:\nНомер группы: ");
    scanf ("%d", &key_num);
    f.num = key_num;
 
    key_surname = new char [50];
    printf ("Фамилия студента: ");
    scanf ("%s", key_surname);
    f.surname = new char [strlen(key_surname)+1];
    strcpy(f.surname, key_surname);
    delete[] key_surname;
 
    printf ("\Количество баллов: ");
    scanf ("%le", &key_ball);
    f.ball = key_ball;
    
        key_predmet = new char [50];
    printf ("Название дисциплины: ");
    scanf ("%s", key_predmet);
    f.predmet = new char [strlen(key_predmet)+1];
    strcpy(f.predmet, key_predmet);
    delete[] key_predmet;
 
};
 
int groups::n = 0;
 
void main()
{
    setlocale (0, "Russian");
    char s;
    groups *Data;
 
    Data = new groups[5];
    for (int i=0; i<5; i++)
        key_fill(Data[i]);
 
    printf("\n\nЗаписей в базе: %d\nНомер группы\tФамилия студента\tКоличество баллов\tДисциплина\n-----------------------------------------------------------------------------\n", Data[0].n);
    for (int i=0; i<5; i++)
        Data[i].tab_display();
 
    do
    {
    char* flight;
    int c_predmet;
    printf ("\nОпределить количество студентов изучающих дисциплину: ");
    scanf ("%s", &flight);
    c_predmet=0;
    for (int i=0; i<5; i++)
        if (Data[i].flight_weight(flight))
        c_predmet+=1;
    printf ("\nКоличество студентов изучающих данную дисциплину равно %d\n", c_predmet);
    cout << "\nЕсли хотите пвоторить поиск, введите <<y>>: ";
        cin >> (s);
        cin.get();
    } while (s == 'y' || s == 'Y');
 
   do
    {
    int lowest_price;
    groups *Data2[5];
    printf ("\nСоздание базы студентов задолжников: ");
    printf ("\nВведите порог: ");
    scanf ("%d", &lowest_price);
    printf("\n\nНомер группы\tФамилия студента\tКоличество баллов\tДисциплина\n-----------------------------------------------------------------------------\n");
    for (int i=0; i<5; i++)
        if (Data[i].is_higher_price(lowest_price)) 
        {
            Data2[i] = new groups(Data[i]);
            (*Data2[i]).tab_display();
        };
    cout << "\nЕсли хотите пвоторить поиск, введите <<y>>: ";
        cin >> (s);
        cin.get();
    } while (s == 'y' || s == 'Y');
   system ("pause"); 
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
31.10.2014, 22:11
Ответы с готовыми решениями:

Как сравнить две строки типа string?
C типом char все просто. Поиск по Фамилии и имени. char name,name1,address, dom; int h=0; cout&lt;&lt;&quot;Введите...

Как сравнить две строки игнорируя различия в регистрах?
Дело в том, что нельзя использовать основные функции, в моей случае tolower, я очень затрудняюсь в написании кода%-)

Как сравнить две строки string, введенных с клавиатуры, и вывести на экран строку которая больше?
Как сравнить две строки string введенных с клавиатуры и вывести на экран строку которая больше ?

21
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6725 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
01.11.2014, 09:22
А мне не нужно никаких олимпиад
Ну и, помимо всего, я не говорил про отсутствие велосипедов вообще. Я говорил про велосипеды вместо стандартных функций. Например, своя strcmp.
Время выполнения не всегда является решающим фактором. Да и где так сильно будет важна разница между скоростью выполнения, занимаемой памятью и т.п. массивов и векторов? В программировании микроконтроллеров? Зато векторы дают хорошие плюшки. Как различные алгоритмы, так и проверка на выход за границу и т.п.

И да, я не считаю, что, если человек изучает плюсы без прослойки из си, то это плохо. Может, даже наоборот, еще и помешает эта прослойка.
Бросать ничего не нужно, надо быть последовательным.
0
 Аватар для Dennis Ritchie
555 / 148 / 58
Регистрация: 27.07.2014
Сообщений: 2,446
01.11.2014, 12:37
Цитата Сообщение от KOPOJI Посмотреть сообщение
Время выполнения не всегда является решающим фактором.
В олимпиадной задаче это критично важно. Например, из-за "endl" программа может не пройти тест из-за "Time Limit", а с '\n' спокойно пройдёт...
Цитата Сообщение от KOPOJI Посмотреть сообщение
Как различные алгоритмы, так и проверка на выход за границу и т.п.
Вот поэтому C и быстрее C++, потому что не проверяет выходы за границы.
Цитата Сообщение от KOPOJI Посмотреть сообщение
А мне не нужно никаких олимпиад
А даже если бы вы захотели, то сомневаюсь, что вы бы смогли выиграть такую олимпиада. Это дано единицам:
Российские студенты выиграли чемпионат мира по программированию
Цитата Сообщение от KOPOJI Посмотреть сообщение
Бросать ничего не нужно, надо быть последовательным.
По-моему, я и делаю последовательно: С -> C++ (это последовательно). А вот C++ -> C - это непоследовательно...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.11.2014, 12:37

Функция: сравнить две строки, и, если строки равны, вернуть 0
Помогите написать следующие функции: int mystrcmp (const char * str1, const char * str2); - функция сравнивает две строки, и, если строки...

Сравнить две строки на различия не учитывая кол-во пробелов и такие различия в буквах как о-и, н-т, в-д.
Здравствуйте. Помогите пожалуйста дополнить программу. Суть программы - нужно сравнить две строки на различия не учитывая кол-во...

Сравнить две строки string
Добрый день Что имеется: vector&lt;string&gt; FIO; string temp; FIO формируется из темпов

Сравнить две строки (посимвольно)
Нужно написать функцию, которая сравнивает две заданные строки (посимвольно). Функция должна вернуть 0, если строки одинаковые, и 1 если...

Сравнить две заданные строки на наличие одинаковых слов
Пусть задано множество строк. Вывести те слова, которые встречаются в каждой из двух заданных строк.


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

Или воспользуйтесь поиском по форуму:
22
Ответ Создать тему
Новые блоги и статьи
Контроль уникальности строк в табличной части документа
Maks 18.06.2026
Алгоритм из решения ниже разработан на примере нетипового документа "ПланированиеСпецтехники" с табличной частью "НаличиеОборудования", разработанного в КА2. Задача: контроль уникальности строк в. . .
Клиент
Uhbif79 18.06.2026
Здесь простой клиент для работы с сервером.
Сервер
Uhbif79 18.06.2026
Выкладываю простейший сервер.
Дефенестрация
kumehtar 18.06.2026
Узнал интересное слово. Дефенестрация. Это когда ты выбрасываешь кого-либо или что-либо из окна. Возьму на вооружение)))
Дихотомия добра и зла
kumehtar 18.06.2026
Как Дзен-буддисты говорят о добре и зле: не нужно воевать против зла, нужно воевать против невежества. Тогда добро станет ествественным, и поэтому вечным. Но дело в том, что невежество всё время. . .
Своя Интернет-Компания
iceja 18.06.2026
Я программист с экономическим образованием, пишу свой проект, это SaaS для бизнесов. Мне нужен co-founder с высшим экономическим образованием, и/ или инвестор. Сейчас проект в интенсивной разработке,. . .
24 Мат модель здравосохранения: функциональные требования к строительству пищеблока
anaschu 18.06.2026
СРесурсами1: финансовый SD-контур, калькулятор функциональных требований пищеблока Сегодня разделили затраты в агенте Экономика по образцу модели НАСОСЫ, добавили расчёт ROI и построили первый. . .
23. что сделано за последнее время.
anaschu 17.06.2026
• Эталон: Клиника НИИ питания РАМН, Москва — централизованный пищеблок, 225 коек, 180 пациентов • Git: репозиторий med2, ветка абсентеизм. Рабочий файл: СРесурсами1_v4. alp • Смежный проект:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru