Форум программистов, компьютерный форум CyberForum.ru

Короткое и длинное слово - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Не могу решить .... http://www.cyberforum.ru/cpp-beginners/thread66607.html
=-O Я некак не могу решыть ...... Вот ети задачи : Задача №1 Васе на день рождения подарили много шариков и игрушечный лазер.Шарики надуты и раскиданы по комнате. Вася заинтересовался,сколько шариков он собьет, выстрелив в выбранном им направлении (если б еще лазер был настоящий!!!). Луч, проходя через шарик,идет дальше.Размеры Васи считать пренебрежительно малыми,а шарики считать...
C++ Вычислить среднее арифметическое Я воще не въезжаю как это все сделать((((помогите пожалуйста, Задание вот: Вычислить среднее арифметическое значение отрицательных элементов матрицы А(К,К), К<= 70, расположенных под главной диагональю. http://www.cyberforum.ru/cpp-beginners/thread66604.html
байты в строку C++
как можно перевести 4 байта F1 08 25 12 а строку А1082512 ?
Алгоритм Магу C++
Требуется найти все минимальные внешне устойчивые множества заданного орграфа, используя алгоритм Магу.
C++ Список массивов (заменить все элем. каждого массива ср. знач. и отсортировать список) http://www.cyberforum.ru/cpp-beginners/thread66546.html
Помогите пожалуйста разобраться с этим заданием. Дан список вещественных массивов (максимально 30 массивов). Каждый массив задается одной строкой в формате: ИМЯ=, максимальная длина строки – 80 символов. Заменить все элементы каждого массива средним значением и отсортировать список в порядке увеличения полученного среднего значения. Полученный список вывести на экран....
C++ Определить количество строк, не содержащих ни одного нулевого элемента Дана целочисленная прямоугольная матрицы. Определить: 1.Количество строк, не содержащих ни одного нулевого элемента. 2.Максимальное из чисел, встречающих в заданной матрице более одного раза. как-то затруднительно, даже не знаю как это воплотить, в паскале знаю, а тут что-то не выходит вообще ( подробнее

Показать сообщение отдельно
Gravity
562 / 556 / 39
Регистрация: 29.01.2009
Сообщений: 1,274
23.11.2009, 20:57     Короткое и длинное слово
NastiKor, почти всё верно, но лучше записывать слова в массив указателей. Например так
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 <stdlib.h>
#include <string.h>
 
#define MAXW 512
 
/* сравнение длин двух строк (слов) */
int slencmp(const void *p1, const void *p2)
{
    char *s1, *s2;
 
    s1 = * (char **) p1;
    s2 = * (char **) p2;
    return strlen(s1) - strlen(s2);
}
 
int main(void)
{
    int i, nw;
    char line[4096], *wordsptr[MAXW], *p;
    const char *delim = " ,:.!?";
 
    printf("Введите строку: ");
    if(fgets(line, sizeof(line), stdin) == NULL)
        return 1;
    
    line[strlen(line)-1] = '\0';
 
    /* 
     * разбиваем строку на слова и добавляем их
     * в массив указателей wordsptr
     */
    for(i = 0, p = line; i < MAXW && 
            (p = strtok(p, delim)) != NULL; i++, p = NULL)
        wordsptr[i] = strdup(p);
 
    /* число считанных слов */
    nw = i;
 
    /* сортировка слов по возрастанию длин */
    qsort(wordsptr, nw, sizeof(char *), slencmp);
 
    printf("Самое короткое слово: %s\n", wordsptr[0]);
    printf("Самое длинное слово: %s\n", wordsptr[nw-1]);
 
    /* освобождение памяти из-под массива */
    for(i = 0; i < nw; i++)
        free(wordsptr[i]);
 
    return 0;
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru