0 / 0 / 0
Регистрация: 14.12.2011
Сообщений: 19
1

Найти слова, которые удовлетворяют условию: длина слов максимальна

14.12.2011, 16:32. Показов 1002. Ответов 7
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Задача на Си:
Дана не пустая последовательность слов (не более 50), в каждом слове не больше 8 символов. Слова разделены пробелами, за последним словом стоит точка. Найти слова, которые удовлетворяют условию: длина слов максимальна.

Вот что написал:
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
#include <stdio.h>
#include <string.h>
#include <conio.h>
#define N 9 
#define M 50
 
void main(){
 
int z, max=0;
 
char ch = ' ', a[M][N], d[M][N];
int i=0, j=0, t=0;
 
while (ch!= '.')
{
    scanf_s("%c", &ch);
 
    while (ch != ' ' && ch != '.')
    {
        a[i][j] = ch;
        j++;
        scanf("%c", &ch);
    }
    a[i][j]='\0'; 
    i++;
    j=0;
}
 
z = strlen (a[j]);
 
t = 0;
i=0;
while (a[i] != '\0'){
    if (z>max){
        max = z;
        t=1;
        d[t] = a[i];
    } else if (z == max){
        t = t+1;
        d[t] = a[i];
    }
    i++;
}
 
}
ругается в этих местах: d[t] = a[i]
error C2106: '=' : left operand must be l-value
Что делаю не так?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.12.2011, 16:32
Ответы с готовыми решениями:

Найти те слова, которые отличаются от последнего слова и длина слов максимальная
Дана непустая последовательность слов (не более 50), в каждом слове не более восьми символов. Слова...

Вывести те слова, которые отличаются от последнего слова и удовлетворяют условию
Дана строка длиной n символов, содержащая слова, т.е. группы символов, разделенные...

Вывести те слова, которые отличаются от последнего слова и удовлетворяют условию
Помогите,пожалуйста,написать программу. Дана строка длиной n символов, содержащая слова, т.е....

Найти слова отличающиеся от последнего и длина слова максимальна
Дана непустая последовательность слов (не более 50), в каждом слове не более восьми символов. Слова...

7
Эксперт С++
5043 / 2622 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
14.12.2011, 16:35 2
Цитата Сообщение от Antojkee Посмотреть сообщение
Что делаю не так?
d - двумерный массив, Вы к нему обращаетесь как к одномерному. d[i] в данном случае будет указатель, а d[i][j] - символ.
Цитата Сообщение от Antojkee Посмотреть сообщение
a[i] != '\0'
Всегда истинно. По той же причине.
0
0 / 0 / 0
Регистрация: 14.12.2011
Сообщений: 19
14.12.2011, 16:51  [ТС] 3
Цитата Сообщение от fasked Посмотреть сообщение
d - двумерный массив, Вы к нему обращаетесь как к одномерному. d[i] в данном случае будет указатель, а d[i][j] - символ.

Всегда истинно. По той же причине.
Как тогда всю строку из одного двумерного массива присвоить другому?
0
Эксперт С++
5043 / 2622 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
14.12.2011, 16:56 4
Цитата Сообщение от Antojkee Посмотреть сообщение
Как тогда всю строку из одного двумерного массива присвоить другому?
Используйте функцию strcpy
1
0 / 0 / 0
Регистрация: 14.12.2011
Сообщений: 19
14.12.2011, 21:33  [ТС] 5
Цитата Сообщение от fasked Посмотреть сообщение
Используйте функцию strcpy
исправил на strcpy (d[t], a[i]);

программа запускается, но выдает ошибку в процессе работы:
Unhandled exception at 0x0100107d in laba4.exe: 0xC0000005: Access violation writing location 0x00000000.
Добавлено через 4 часа 20 минут
Вроде бы всё исправил, кроме этого:
Цитата Сообщение от fasked Посмотреть сообщение
a[i] != '\0'
Всегда истинно. По той же причине.
Как это исправить? тоже через какую-то функцию?
0
go
Эксперт С++
3646 / 1378 / 243
Регистрация: 16.04.2009
Сообщений: 4,526
14.12.2011, 21:45 6
Цитата Сообщение от fasked Посмотреть сообщение
Используйте функцию strcpy
И как же с двумерными массивами?
Цитата Сообщение от Antojkee Посмотреть сообщение
исправил на strcpy (d[t], a[i]);
программа запускается, но выдает ошибку в процессе работы:
Используйте strncpy...

Добавлено через 4 минуты
А вообще лучше так
C
1
2
3
4
5
6
7
8
char *A[N];
char buf[BUFSIZ];
 
for ( i = 0 ; i < N ; ++i )
{
        fgets (buf, BUFSIZ, stdin);
        A[i] = strdup (buf);
}
1
0 / 0 / 0
Регистрация: 14.12.2011
Сообщений: 19
14.12.2011, 23:37  [ТС] 7
В общем, написал
Возможно кому-нибудь попадётся подобная или такая же задачка.

Решение:

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
#include <stdio.h>
#include <string.h>
#include <conio.h>
#define N 8
#define M 50
 
void main(){
 
int max=0;
 
char ch = ' ', a[M][N], d[50][N];
int i=0, j=0, t=0,k;
 
while (ch!= '.')
{
    scanf("%c", &ch);
 
    while (ch != ' ' && ch != '.')
    {
        a[i][j] = ch;
        j++;
        scanf("%c", &ch);
    }
    a[i][j]='\0'; 
    i++;
    j=0;
}
k = i-1;
max = 0;
i=0;
 
while (i <= k){
    if ((strstr(a[i],a[k])) == NULL){
        if ( strlen (a[i]) > max ){
            max = strlen (a[i]) ;   
            t=0;
            strcpy (d[t], a[i]);
        } else if (strlen (a[i]) == max){
            t = t+1;
            strcpy (d[t], a[i]);
        }
    }
    i++;
}
 
k=t;
 
for (t = 0; t <= k; t++ ) puts(d[t]);
 
_getch();
}
Всем спасибо за помощь
0
Эксперт С++
5043 / 2622 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
15.12.2011, 02:13 8
Цитата Сообщение от go Посмотреть сообщение
И как же с двумерными массивами?
Прошу прощения, не понял вопроса В цикле само собой.
Тут кстати массив статический, можно вообще одним memcpy всю таблицу кинуть
0
15.12.2011, 02:13
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.12.2011, 02:13
Помогаю со студенческими работами здесь

Строки. Напечатать слова, длина которых максимальна
Спасибо заранее за помощь

Напечатать те слова последовательности, которые отличны от первого слова и удовлетворяют следующему свойству
Напечатать те слова последовательности, которые отличны от первого слова и удовлетворяют следующему...

Найти среднюю длину слов и удалить из текста все слова длина, которых меньше найденного значения
Найти среднюю длину слов и удалить из текста все слова длина, которых меньше найденного значения....

Даны три слова. Напечатать те буквы слов, которые есть в одном из слов
Условие: Даны три слова. Напечатать только те буквы слов, которые есть только в одном из слов....


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

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

Новые блоги и статьи
В чем отличие между INNER JOIN и OUTER JOIN
bytestream 22.01.2025
В современных базах данных информация часто распределена между множеством взаимосвязанных таблиц, что делает операции объединения JOIN неотъемлемой частью работы с SQL. Эти операции позволяют. . .
Как сделать первую букву заглавной в JavaScript
bytestream 22.01.2025
JavaScript предоставляет разработчикам множество инструментов для эффективной работы с текстовыми данными. Одной из часто встречающихся задач при обработке строк является преобразование первой буквы. . .
Что такое Big O нотация и алгоритмическая сложность
bytestream 22.01.2025
Введение в алгоритмическую сложность В мире разработки программного обеспечения эффективность алгоритмов играет crucial роль в создании качественных приложений. Алгоритмическая сложность. . .
Как решать конфликты слияния (merge) в Git
bytestream 22.01.2025
Конфликты слияния в системе контроля версий Git возникают в ситуациях, когда две или более ветки разработки содержат несовместимые изменения в одних и тех же участках кода. Эти конфликты представляют. . .
Как использовать регулярные выражения
bytestream 22.01.2025
Регулярные выражения представляют собой мощный инструмент для работы с текстовыми данными, который позволяет осуществлять поиск, проверку и манипуляцию строками на основе определенных шаблонов. Этот. . .
Как выйти из Vim
bytestream 22.01.2025
Vim (Vi IMproved) представляет собой один из самых влиятельных текстовых редакторов в истории компьютерной индустрии, эволюционировавший из своего предшественника Vi, созданного Биллом Джоем в 1976. . .
NoSQL базы данных: что это такое и какие существуют
bytestream 22.01.2025
В современную эпоху цифровой трансформации объемы данных растут экспоненциально, создавая новые вызовы для традиционных систем управления базами данных. NoSQL (Not Only SQL) представляет собой. . .
Обновление исследования от команды MCM (январь 2025 г.)
Programma_Boinc 22.01.2025
Обновление исследования от команды MCM (январь 2025 г. ) Мы продолжаем изучать молекулярные сигнатуры, связанные с раком легких, с текущим фокусом на GCM1, факторе транскрипции, участвующем в. . .
Как работать с Kafka в Go (Golang)
bytestream 22.01.2025
Apache Kafka представляет собой распределенную платформу потоковой передачи данных, которая произвела революцию в области обработки событий и интеграции микросервисов. Эта система, изначально. . .
Как использовать RabbitMQ в Go (Golang)
bytestream 22.01.2025
RabbitMQ представляет собой надежный и широко используемый брокер сообщений, который играет ключевую роль в построении современных распределенных систем и микросервисной архитектуры. В основе работы. . .
Как преобразовать список списков в простой список в Python
bytestream 22.01.2025
При работе с Python разработчики часто сталкиваются с необходимостью обработки сложных структур данных, среди которых особое место занимают вложенные списки. Эти структуры представляют собой списки,. . .
Что такое GUID / UUID и как их создать
bytestream 22.01.2025
В мире разработки программного обеспечения существует постоянная потребность в уникальной идентификации объектов, записей и ресурсов. Эта задача становится особенно актуальной в распределенных. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru