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

строки В С - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Подскажите пожалуйста о case?? http://www.cyberforum.ru/cpp-beginners/thread57071.html
Здравствуйте!!! У меня есть такой вопрос, для чего служить ключевое слово case ?? Лучше если напишете примеры его правильного использования!!! Спасибо!!!
C++ link of file ! объясните мне плиз ! результат кода #include<iostream.h> void main(int n, char*s) { cout<<s; int i=1; while(i<n) cout<<s; cout<<'\n'; http://www.cyberforum.ru/cpp-beginners/thread57060.html
C++ Уважаемы программисты помогите пожалуйста срочно нужно
Уважаемы программисты я хотел бы у вас попросить помочь мне в решении задачи на С не с++ Задача звучит так Даны строки нужно отсортировать каждую строку таким образом что бы в начале строки...
Определить средний балл группы по каждому предмету C++
Необходимо написать программу, в которой необходимо: создать файл с фамилиями студентов группы и, используя его, сформировать ведомость результатов сессии (5 экзаменов) в виде целочисленной матрицы...
C++ Вопрос по хранению бинарного дерева http://www.cyberforum.ru/cpp-beginners/thread57021.html
Недавно задали задачку в универе... Лет 7 занимаюсь программированием, вроде пока серьезных траблов не было ни с серьезными математическими расчетами ни с тем же самым DirectX и всем сопутствующим....
C++ Структура, переменные, объект... Помогите пожалуйста: Написать программу с использованием структуры, состоящей из переменных, определяющих объект «Студент»: фамилия, номер группы: А. Инициализация элементов структуры... подробнее

Показать сообщение отдельно
ProNoooob
74 / 74 / 6
Регистрация: 14.10.2009
Сообщений: 121
17.10.2009, 22:31
Получилось целых 70 строк. Я сам не эксперт по сортировке, но вот что получилось.
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
#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
#include <conio.h>
#include <string.h>
 
struct word
{
    char *p;          //позиция начала слова в строке
    int leangth;      //длинна слова
};
 
int sravnenie(const void *a, const void *b) //это функция сравнения необходима для сортировки.
{
    struct word *c = (struct word *)a;
    struct word *d = (struct word *)b;
    return ((*c).leangth - (*d).leangth);
}
 
int main()
{
    char buffer[256];                   //тут храним исходную строчку
    char stroka[256] = {0};             //а тут после сортировки
    char *pointer = &stroka[0];            //это указател, ибо с ним легче работать
    unsigned char i = 0;                //просто переменная счетчик
    struct word words[20];              //массив для хранения дилы и позиции слов в строке
    char new_word = 0;                  //тоже "техн" переменная    
    unsigned char kolli4estvo_slov = 0; //колличество слов в строке(очень важно)
 
    gets(buffer);            //читаем строчку вида слово пробел слово пробел
    while(buffer[i] != '\0') //ищем слова в строке
    {
        if(isgraph(buffer[i]))
        {
            if(!new_word)
            {
                words[kolli4estvo_slov].p = &buffer[i]; //запоминаем позицию слова в строке
                words[kolli4estvo_slov].leangth = 1; 
                new_word = 1;
            }
            else
            {
                words[kolli4estvo_slov].leangth++;
            }
        }
        else if(isspace(buffer[i]))
        {
            new_word = 0;
            kolli4estvo_slov++;
        }
        i++;
    }
 
    qsort(words, kolli4estvo_slov+1, sizeof(struct word), sravnenie); //стандартная функция сортировки языка С
 
    for(i = 0; i < (kolli4estvo_slov + 1); i++)                //склеиваем строку результат
    {
        memcpy(pointer, words[i].p, words[i].leangth);
        pointer += words[i].leangth;
        *pointer = ' ';
        pointer++;
    }
 
    printf("%s", stroka);    //печатаем результат
 
    getch(); //чтобы не закрывалась сразу :-)
 
    return 0;
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru