Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
redodman
0 / 0 / 0
Регистрация: 09.12.2009
Сообщений: 10
#1

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

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

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

И все таки . Хотелось бы услышать ответ .
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.12.2010, 18:15
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Вывести все слова входного потока в порядке увеличения их длины (C++):

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

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

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

Вывод строк фиксированной длины из входного потока - C++
Задача организовать цикл по входному потоку и вывести полученные getchar'ом символы в виде строк некоторой длины N. Допустим, если длина...

Слова входного потока - C++
Вывести самые длинные слова входного потока! если во вх потоке самое длинное слово одно,то программа должна вывести одно слово,а если...

Вывести слова строки в порядке убывания длины - C++
требуется написать программу которая: -считает количество слов в предложении -выводит слова строки в порядке убывания ее длины ...

6
igorrr37
1648 / 1276 / 133
Регистрация: 21.12.2010
Сообщений: 1,932
Записей в блоге: 7
29.01.2011, 17:51 #2
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
2925 / 1354 / 135
Регистрация: 29.11.2010
Сообщений: 2,725
30.01.2011, 13:51 #3
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
redodman
0 / 0 / 0
Регистрация: 09.12.2009
Сообщений: 10
31.01.2011, 19:40  [ТС] #4
При попытке запуска последней программы .. компилятор выдает ошибки
Я мало что понимаю в ней . изза этого прошу помощи .
Ошибки : Cannot convert ' void *' to 'char *'
Type mismatch in parameter '__dest' in call to 'strcpy(char *,const char *)'
0
lemegeton
2925 / 1354 / 135
Регистрация: 29.11.2010
Сообщений: 2,725
31.01.2011, 20:43 #5
C
1
new_item->data = strcpy(malloc(string_length + 1), string);
на
C
1
new_item->data = strcpy((char*)malloc(string_length + 1), string);
1
redodman
0 / 0 / 0
Регистрация: 09.12.2009
Сообщений: 10
31.01.2011, 23:32  [ТС] #6
Огромное спасибо .
0
easybudda
Модератор
Эксперт CЭксперт С++
9698 / 5648 / 964
Регистрация: 25.07.2009
Сообщений: 10,863
01.02.2011, 00:42 #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
#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
01.02.2011, 00:42
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
01.02.2011, 00:42
Привет! Вот еще темы с ответами:

Вывести на экран слова текста в порядке невозрастания их длины - C++
Из произвольного текста, содержащего не более 10 строк, в каждой строке не более 80 символов, вывести на экран слова в порядке не...

Дана строка, вывести слова наименьшей длины в порядке возрастания - C++
Здравствуйте! Помогите, пожалуйста, с программой: дана строка, вывести слова наименьшей длины в порядке возрастания.

Дан текст, вывести на экран слова в порядке уменьшения их длины! - C++
Дан одномерный Массив написать программу преобразования массива путём сдвига их значений! Добавлено через 1 минуту С++ Робота со...

Дано два числа А и В (А<В). Вывести в порядке увеличения все целые числа - C++
Дано два числа А и В (А&lt;В). Вывести в порядке увеличения все целые числа, расположеные между А и В(не включая чисед А и В), а также...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.