Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/9: Рейтинг темы: голосов - 9, средняя оценка - 4.78
0 / 0 / 0
Регистрация: 09.12.2009
Сообщений: 10

Вывести все слова входного потока в порядке увеличения их длины

26.12.2010, 18:15. Показов 1871. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте .
Задание: Вывести все слова входного потока в порядке увеличения их длины .
Надеюсь на вашу помощь. Задание желательно сделать на Си а не на Си++

И все таки . Хотелось бы услышать ответ .
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
26.12.2010, 18:15
Ответы с готовыми решениями:

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

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

Вывести все слова входного потока, заканчивающиеся заданной последовательностью символов
Пожалуйста помогите!

6
 Аватар для igorrr37
2872 / 2019 / 991
Регистрация: 21.12.2010
Сообщений: 3,754
Записей в блоге: 9
29.01.2011, 17:51
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include<iostream>
#include<algorithm>
#include<sstream>
#include<set>
using namespace std;
 
bool comp(string a, string b){
    return a.size()<b.size();
}
 
void show(string a){
    cout<<a<<"\n";
}
 
int main(){
    multiset<string, bool(*)(string, string)> con(comp);
    string s;
    getline(cin, s);
    stringstream ss(s);
    while(ss>>s) con.insert(s);
    for_each(con.begin(), con.end(), show);
}
2
 Аватар для lemegeton
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
30.01.2011, 13:51
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
#include <stdio.h>
#include <string.h>
#include <stddef.h>
#include <stdlib.h>
 
struct ListItem {
  char *data;
  size_t length;
  struct ListItem *next;
  struct ListItem *prev;
};
 
void AddToList(struct ListItem **list, const char *string) {
  size_t string_length = strlen(string);
  struct ListItem* new_item = (struct ListItem*)malloc(sizeof(struct ListItem));
  new_item->data = strcpy(malloc(string_length + 1), string);
  new_item->length = string_length;
 
  if (*list == NULL) {
    new_item->next = NULL;
    new_item->prev = NULL;
    *list = new_item;
  } else {
    struct ListItem *prev_item = (*list)->prev;
    struct ListItem *next_item = *list;
    while (next_item != NULL && new_item->length > next_item->length) {
      prev_item = next_item;
      next_item = next_item->next;
    }
    new_item->next = next_item;
    new_item->prev = prev_item;
    if (prev_item != NULL)
      prev_item->next = new_item;
    if (next_item != NULL)
      next_item->prev = new_item;
    if (next_item == *list)
      *list = new_item;
  }
}
 
void ClearList(struct ListItem **list) {
  if (*list == NULL)
    return;
  struct ListItem* next;
  while (*list != NULL) {
    next = (*list)->next;
    free((*list)->data);
    free(*list);
    *list = next;
  }
}
 
int main(int argc, char  **argv) {
  size_t buffer_size = 2048;
  char *buffer = (char*)malloc(buffer_size);
 
  struct ListItem *list = NULL;
 
  while (!feof(stdin)) {
    if (scanf("%s", buffer) > 0)
      AddToList(&list, buffer);
  }
 
  if (list != NULL) {
    struct ListItem* item = list;
    while (item != NULL) {
      printf("%s\n", item->data);
      item = item->next;
    }
  }
 
 
  ClearList(&list);
 
  free(buffer);
  return 0;
}
1
0 / 0 / 0
Регистрация: 09.12.2009
Сообщений: 10
31.01.2011, 19:40  [ТС]
При попытке запуска последней программы .. компилятор выдает ошибки
Я мало что понимаю в ней . изза этого прошу помощи .
Ошибки : Cannot convert ' void *' to 'char *'
Type mismatch in parameter '__dest' in call to 'strcpy(char *,const char *)'
0
 Аватар для lemegeton
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
31.01.2011, 20:43
C
1
new_item->data = strcpy(malloc(string_length + 1), string);
на
C
1
new_item->data = strcpy((char*)malloc(string_length + 1), string);
1
0 / 0 / 0
Регистрация: 09.12.2009
Сообщений: 10
31.01.2011, 23:32  [ТС]
Огромное спасибо .
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,973
01.02.2011, 00:42
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
int asc_cmp(const void * a, const void * b) { return strlen(*(char**)a) - strlen(*(char**)b); }
 
#define DELIM " \t\n"
 
int main(void){
    char buf[BUFSIZ], * p, ** words;
    size_t i, count;
    
    while ( printf("\nString: ") && fgets(buf, BUFSIZ, stdin) && *buf != '\n' ){
        words = NULL;
        count = 0;
        for ( p = strtok(buf, DELIM); p; p = strtok(NULL, DELIM) ){
            if ( ( words = (char**)realloc(words, sizeof(char*) * (count + 1)) ) == NULL ){
                perror("realloc");
                exit(1);
            }
            if ( ( words[count++] = strdup(p) ) == NULL ){
                perror("strdup");
                exit(1);
            }
        }
        if ( ! words || ! count ){
            fprintf(stderr, "No words in row!\n");
            continue;
        }
        qsort(words, count, sizeof(char*), asc_cmp);
        for ( i = 0; i < count; ++i )
            printf("%s\n", words[i]);
        
        while ( count )
            free(words[--count]);
        free(words);
    }
    
    exit(0);
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.02.2011, 00:42
Помогаю со студенческими работами здесь

Расположите слова в порядке увеличения длины слова
Есть файл docx с набором слов, нужно открыть его и напечатать эти слова в порядке увеличения слова, буду благодарен за помощь unit...

Вывести лова в порядке увеличения их длины
Посчитайте распределение слов по длине во введённой строке текста. Выведите на экран строки следующего вида: &lt;длина слова&gt;...

Все слова из входного потока поместить в выходной поток с новой строки
Здравствуйте уважаемые программисты помогите пожалуйста текст задачи: все слова из входного потока, помещать в выходной поток с новой...

Вывести слова в порядке увеличения их длин
В Edit1 задано несколько слов, отделенных друг от друга одним пробелом. Вывести в MEMO1 эти слова в порядке увеличения их длин.

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


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru