Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/18: Рейтинг темы: голосов - 18, средняя оценка - 5.00
1 / 1 / 0
Регистрация: 17.04.2011
Сообщений: 142

Ввести n строк, найти самую короткую и самую длинную строки

25.02.2012, 14:03. Показов 3544. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ввести n строк , найти самую короткую и самую длинную строки. Вывести
найденные строки и их длину. Ввод осуществить как аргументы командной строки.
Написал такой код, но он не верно работает, под виндоус выдает 1 и виснет, а на линуксе просто не верно считает...

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
#include <stdio.h>
#include <string.h>
 
void main(int argc, char *argv[])
{
    int i,j,f=1,w=1; char str[10]; /*f - число повторений. w - номер необходимого аргумента*/
    for (j=1;j<argc;j++)
    {  
        strncat(str, argv[j],strlen(argv[j])); 
        for (i=1;i<strlen(argv[j]);i++)
        {   
            if (str[i]>str[i-1])
            {
                ++f; 
        }
        }    
             printf("f= %d",f);
             printf("\n");
            if (f==strlen(argv[j]))
            {
                 w=j; 
            }
            f=1;
    } 
    printf("%d",strlen(argv[w]));
    printf("\n");
    strncat(str, argv[w],strlen(argv[w]));
    for (i=0;i<strlen(argv[w]);i++)
    {
        printf("%c",str[i]);
    }
    printf("\n");
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.02.2012, 14:03
Ответы с готовыми решениями:

В тексте найти самую длинную и самую короткую строки и поменять их местами
в тексте найти самую длинную и самую короткую строки и поменять их местами

Найти самую короткую строку в файле
Задача программы - найти самую короткую строку в файле Если не сложно,можете для большего понятия - к каждой строке оставить...

Считывает набор строк и выводит самую длинную из них
#include &lt;stdio.h&gt; #define N 100 int main() { char sym, max; int m=0, len; for (int i = 0; i &lt; N; i++) { sym = '\0'; ...

3
go
Эксперт С++
3646 / 1378 / 243
Регистрация: 16.04.2009
Сообщений: 4,526
25.02.2012, 14:42
Цитата Сообщение от Liv-pooL Посмотреть сообщение
void main(int argc, char *argv[])
Почитайте про функцию main

Цитата Сообщение от Liv-pooL Посмотреть сообщение
под виндоус выдает 1 и виснет, а на линуксе просто не верно считает...
Покажите пример запуска.
0
1 / 1 / 0
Регистрация: 17.04.2011
Сообщений: 142
25.02.2012, 14:57  [ТС]
Я читал про функцию.
А что касается результатов, окно с цифрой один и "прекращение работы программы"...

Если бы все можно было найти в инете, я бы не обратился за помощью...
0
go
Эксперт С++
3646 / 1378 / 243
Регистрация: 16.04.2009
Сообщений: 4,526
25.02.2012, 15:28
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
int main(int argc, char* argv[])
{
    if ( argc < 2 )
    {
        fprintf(stderr, "%s:Error arg\n", argv[0]);
        exit(1);
    }
    else
    {
        char *min = argv[1], *max = argv[1];
        size_t i;
        for ( i = 2 ; i < argc ; ++i )
            if ( strlen(min) > strlen(argv[i]) )
                min = argv[i];
            else
                if ( strlen(max) < strlen(argv[i]) )
                    max = argv[i];
        printf("Max : %s \t Min : %s\n", max, min);
    }
    return 0;
}
Bash
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
andrey@andrey-VirtualBox:~/mydev$ cat arg_com_str.c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
int main(int argc, char* argv[])
{
    if ( argc < 2 )
    {
        fprintf(stderr, "%s:Error arg\n", argv[0]);
        exit(1);
    }
    else
    {
        char *min = argv[1], *max = argv[1];
        size_t i;
        for ( i = 2 ; i < argc ; ++i )
            if ( strlen(min) > strlen(argv[i]) )
                min = argv[i];
            else
                if ( strlen(max) < strlen(argv[i]) )
                    max = argv[i];
        printf("Max : %s \t Min : %s\n", max, min);
    }
    return 0;
}
andrey@andrey-VirtualBox:~/mydev$ gcc -o arg_com_str arg_com_str.c
andrey@andrey-VirtualBox:~/mydev$ ./arg_com_str
./arg_com_str:Error arg
andrey@andrey-VirtualBox:~/mydev$ ./arg_com_str String
Max : String     Min : String
andrey@andrey-VirtualBox:~/mydev$ ./arg_com_str String str s
Max : String     Min : s
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.02.2012, 15:28
Помогаю со студенческими работами здесь

Считать набор текстовых строк и напечатать самую длинную из них
Программа читает набор текстовых строк и печатает самую длинную из них. Код: #include &lt;stdio.h&gt; #define MAX_LINE 1000 ...

Найти самую длинную и самую короткую строки в файле
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using...

В текстовом файле найти самую длинную и самую короткую строки
Тема: Создание и обработка текстовых файлов. Цель: Написание и отладка программ обработки текстовых файлов. В текстовом файле найти...

Определить самую длинную и самую короткую из введенных строк
Необходимо организовать ввод 3 названия городов. А потом вывести на экран консольно самое длинное и короткое название города. Лезут ошибки...

Поменять местами самую короткую и самую длинную строки текста (при условии, что они единственны)
Дан текстовый файл f. Поменять местами самую короткую и самую длинную строки текста (при условии, что они единственны), результат занести в...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru