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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ экспрес ругается на #include "stdafx.h". Что делать? http://www.cyberforum.ru/cpp-beginners/thread220772.html
запуская программу в ВС Экспресс 2008. выдает вот такую ошибку: Не удается открыть файл include: stdafx.h: No such file or directory что делать,расскажите пожалуйста) Добавлено через 4 минуты...
C++ «Линейный и разветвляющийся алгоритмы» Составить программу для вычисления Yи Z по заданным формулам, определить min(Y;Z). Y =-(4x^2+a^2/3)^1/2 Z = (5*cos(x*a)^3-1)/((x*a)^1/3+2,5) Помогите ,ПОЖАЛУЙСТА,найти ошибки в программе. ... http://www.cyberforum.ru/cpp-beginners/thread220771.html
C++ ООП-отчет
помогите написать отчет, очень нужно!!!!! /*Определить класс "квадратная матрица", операции матричного умножения, сложения, вычитания, транспонирования, доступ к элементу матрицы по его...
Внутреннее использование strtok C++
Добрый вечер. Нужна Ваша срочная помощь. Мне нужно разбирать 2 строки на слова и каждое слово первой строки сравнить со словами второй, все было бы просто, но вот внутренное использование функции...
C++ Арифм.Прогрессия http://www.cyberforum.ru/cpp-beginners/thread220748.html
Уже целый день сижу над задачей, но покачто получался только бред... Вот сама задача: Добавить к некоторой последовательности A=(ai), i=1..n, n<=100, наименьшее число элементов, чтобы ...
C++ Список указателей Имеется структура данных, состоящая из 2 ух полей, необходимо создать отсортированный список указателей на эту структуру. Как создать отсортированный список структур я понимаю, а вот с указателями... подробнее

Показать сообщение отдельно
lemegeton
2924 / 1353 / 135
Регистрация: 29.11.2010
Сообщений: 2,725
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
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru