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

Упорядочить слова в алфавитном порядке на С - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Непонятная работа вывода http://www.cyberforum.ru/cpp-beginners/thread421378.html
Почему при выводе переменной а выводится 1, хотя перед тем как вывести ее выполняется lol(а)? Причем, при следующем выводе а выводится правильное значение(2). int lol(int &a) { a++; return 0; } int main()
C++ как дописать в файл Столкнулся со следующей задачей, не знаю как сделать. В процессе работы кода нужно периодически сохранять массив данных в текстовый файл. Вначале сделал просто - дописывается столбец в конец файл. Но это неудобно. Хочу сделать так, чтобы каждый раз в файл добавлялась колонка из данных. Т.е. например был файл 1 -1 2 -2 3 -3 4 -4 А на следующем шаге дописывается колонка: 1 ... http://www.cyberforum.ru/cpp-beginners/thread421360.html
C++ Дан числовой массив,Дано предложение.
Часть 1. Дан числовой массив. Реализовать алгоритм сортировки вставками. Часть 2. Дано предложение(ввод с клавиатуры). Удалить из неё все буквы «e» и «m»
выводит не все пути C++
#include <stdio.h> #include <conio.h> #include <stdlib.h> int a; int n; int sp,ep; int *was,*pom,*path,cpath; FILE *f1;
C++ Исходник шахмат http://www.cyberforum.ru/cpp-beginners/thread421325.html
Здравствуйте! У кого - нибудь он есть?
C++ Типы переменных. В чём проблема? 5806599110 - число слишком большое для типа long long? sizeof(long long) пишет, что 8 байт. Вывожу на экран через std::cout подробнее

Показать сообщение отдельно
Gepar
 Аватар для Gepar
1173 / 529 / 20
Регистрация: 01.07.2009
Сообщений: 3,508
02.01.2012, 16:35     Упорядочить слова в алфавитном порядке на С
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
 
/* оболочка strcmp(const char*, const char*) для функции qsort */
int compareStrings(const void *a, const void *b){
        return strcmp(*(char**)a, *(char**)b);
}
 
/* указатель на следующее слово в строке, или 0, если слова кончились */
char *nextWord(char *str){
        char *p;
        for ( p = str; *p != '\0' && !isspace(*p) && !ispunct(*p); p++ )
                ;
        if ( *p == '\0' )
                return NULL;
        while ( isspace(*p) || ispunct(*p) )
                p++;
        return ( *p == '\0' ) ? NULL : p;
}
 
/*
*       возвращает одно слово из строки str в буфере wrd. динна wrd = len - 1
*       в случае неудачи вернёт NULL
*/
char *getWord(const char *str, char *wrd, size_t len){
        char *p;
        char *w;
 
        for ( p = (char *)str, w = wrd;  *p != '\0' && !isspace(*p) && !ispunct(*p) && --len > 0; p++, w++ )
                *w = *p;
        *w = '\0';
 
        return wrd;
}
 
int main(){
        char buf[BUFSIZ];
        char wrd[BUFSIZ];
        char **arr, *pBuf;
        int count, i;
        size_t len;
 
        printf("Enter some string: ");
        fgets(buf, BUFSIZ, stdin);
        if ( strlen(buf) < 2 ) { /* в строке только \n */
                printf("Empty string not allowed\n");
                exit(1);
        }
        buf[strlen(buf) - 1] = '\0';
        /* подсчёт слов */
        for ( count = 0, pBuf = buf; pBuf != NULL; count++, pBuf = nextWord(pBuf) )
                ;
        if ( !count ) {
                printf("Empty string not allowed\n");
                exit(1);
        }
 
        /* массив указателей на слова */
        if ( (arr = (char **)calloc(count, sizeof(char*))) == NULL ){
                printf("Memory error\n");
                exit(1);
        }
 
        /* заполнение массива словами */
        for ( i = 0, pBuf = buf; i < count && pBuf != NULL; i++, pBuf = nextWord(pBuf) ){
                if ( getWord(pBuf, wrd, BUFSIZ) == NULL )
                        break; /* на всякий случай */
                len = strlen(wrd);
                if ( (arr[i] = (char *)malloc(len + 1)) == NULL ) {
                        printf("Not enough memory\n");
                        exit(1);
                }
                strcpy(arr[i], wrd);
        }
 
        /* сортировка массива */
        qsort((void*)arr, count, sizeof(char*), compareStrings);
 
        /* вывод */
        for ( i = 0; i < count; i++ )
                printf("%s ", arr[i]);
 
        /* освобождение памяти */
        for ( i = 0; i < count; i++ ){
                free(arr[i]);
                arr[i] = NULL;
        }
        free(arr);
        arr = NULL;
 
        getch();
 
        exit(0);
}
Код взят на форуме, только не помню в какой теме, и автора тоже к сожалению не помню (код валялся в файле на винчестере), но если он(автор кода) зайдёт в тему то думаю отпишеться )
 
Текущее время: 04:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru