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

Сортировка по алфавиту - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Не понимаю как доделать программу http://www.cyberforum.ru/cpp-beginners/thread1021695.html
Требования: нужно,организовать массив из тех чисел, которые входят в последовательность более одного раза. Вот я создал 2 массива, заполнил их числами, как теперь сделать так,чтобы последовательность чисел падала в массив С.Заранее благодарен #include<stdlib.h> #include<iostream> using namespace std; const int n=60; int main() { int a,b, c; int i,j,k,m=0;
C++ Объект общего вида (Object) в консольном приложении Всем привет. Не смог понять одной вещи: есть ли возможность создать функцию с аргументом типа Object(Любой объект, чтоб, что я туда не передам - всё бы съелось), как в VB, C#, Java или Obcect Pascal? Я нашел, что такое существует при использовании пространства имен System, но такое пространство имен в консоли не подключить (или не получается именно у меня). Как быть? http://www.cyberforum.ru/cpp-beginners/thread1021684.html
Функция внутри структуры использует указатель, как поле этой структуры C++
Коротко, есть класс A, описан в файле A_class.h ну и реализованы функции в A_class.cpp, есть файл GlobalItems.h, где хранятся глобальные структуры проекта внутри GlobalItems.h есть такая структура: extern class A; struct B { A* A_Obj; void Func ( ) { A_Obj->Example ();
Move конструктор && C++
Никак не могу понять, что же он делает. Вроде как пишут, что он даже предпочтительнее, чем всякие const MyType& var в качестве параметров в функции, но почему? Что же он на самом деле делает? Допустим, & в данном случае - просто обертка над указателем.
C++ Определить, есть ли в массиве значение, равное (min +max) / 2 http://www.cyberforum.ru/cpp-beginners/thread1021644.html
Здравствуйте , решите пожалуйста задачку) Поступила на заочку , а там ничего не объясняют...как учиться ума не приложу( такую дали : Определить, есть ли в массиве L значение, равное (min +max) / 2 и вывести номер первого значения, если есть, иначе сообщить, что нет.
C++ Постройте таблицу значений функции с помощью функции Постройте таблицу значений функции y=f(x) для Х€ с шагом h. Если в некоторой точке х функция не определена, то выведите на экран сообщение об этом. Замечание. Для решения задачи использовать вспомогательную функцию. y=3х+4:корень х2-1 подробнее

Показать сообщение отдельно
PolApelcina
0 / 0 / 0
Регистрация: 30.10.2013
Сообщений: 31
28.11.2013, 12:06     Сортировка по алфавиту
Ребят, нужна помощь.
Суть задания: сформировать список книг и отсортировать его по ФИО автора. Сам список я создал, но помогите написать сортировку этого списка по алфавиту по ФИО автора.Заранее спасибо.
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <time.h>
#include <string.h>
#include <locale.h>
 
struct element 
{
    char Famil[30];
    char Name[30];
    char Patr[30];
    char NameB[30];
    char Izdat[30];
    int god;
    int nums;
};
struct Spisok
{
    struct element *kniga;
    struct Spisok *pNext;
    struct Spisok *pPred;
};
struct Spisok *First(struct element *kniga,struct Spisok *ptrnext)
{
    ptrnext=new struct Spisok;
    if (ptrnext==NULL)
        return NULL;
    ptrnext->pNext=NULL;
    ptrnext->pPred=NULL;
    ptrnext->kniga= kniga;
    return ptrnext;
    delete [] ptrnext;
}
void next(struct element *kniga,struct Spisok *lol)
{
    struct Spisok *ptrnext;
    for(lol;lol->pNext != NULL;)
    {
        lol = lol->pNext;
    }
    ptrnext=new struct Spisok;
    if (ptrnext==NULL) return;
    ptrnext->pNext=NULL;
    lol->pNext = ptrnext;
    ptrnext->pPred=lol;
    ptrnext->kniga=kniga;
}
void print (struct Spisok *print)
{
    int i=1;
    do
    {
        printf("\n%d) Ф.И.О автора: %s %s %s",i, print->kniga->Famil, print->kniga->Name,print->kniga->Patr);
        printf("\nНазвание: %s\t Издательство: %s \nКол-во страниц: %d\t год: %d",print->kniga->NameB,print->kniga->Izdat,print->kniga->nums,print->kniga->god);
        print=print->pNext;
        ++i;
    }
    while(print->pNext);
    printf("\n%d) Ф.И.О автора: %s %s %s",i, print->kniga->Famil, print->kniga->Name,print->kniga->Patr);
    printf("\nНазвание: %s\t Издательство: %s \nКол-во страниц: %d\t год: %d\n",print->kniga->NameB,print->kniga->Izdat,print->kniga->nums,print->kniga->god);
    
}
struct Spisok *first = NULL;
void main()
{
    setlocale ( LC_ALL, "rus" );
    int n,i,k;
    char *Famman[8]={"Сидоров","Плюшкин","Комаров","Смирнов","Бурченко","Абдулов","Гончаров","Горбачев"};
    char *Imyaman[8]={"Даниил","Аркадий","Николай","Григорий","Анатолий","Евгений","Андрей","Денис"};
    char *Patrman[8]={"Владимирович","Петрович","Иванович ","Аркадиевич","Николаевич","Егорович","Андреевич","Максимович"};
    char *izdatel[5]={"Москва","Восход","Экватор","Курабейн","Гейзер"};
    char *NameBook[5]={"Горбатая Гора","Дирижабль","АБВГДейка","Механика","Дикий Запад"};
    struct element *knigastr;
    printf ("Введите кол-во книг: ");
    scanf("%d",&n);
    knigastr=new struct element;
    srand ((int)time(NULL));
    k=rand() % 8;
    strcpy(knigastr->Famil,Famman[k]);
    k=rand() % 8;
    strcpy(knigastr->Name,Imyaman[k]);
    k=rand() % 8;
    strcpy(knigastr->Patr,Patrman[k]);
    k=rand() % 5;
    strcpy(knigastr->Izdat,izdatel[k]);
    k=rand() % 5;
    strcpy(knigastr->NameB,NameBook[k]);
    knigastr->god = rand() %213 + 1700;
    knigastr->nums = rand () %600 + 1;
    first=First(knigastr,first);
    if(first == NULL) exit(1);
    for(i=1; i < n; i++)
    {
        knigastr=new struct element;
        k=rand() % 8;
        strcpy(knigastr->Famil,Famman[k]);
        k=rand() % 8;
        strcpy(knigastr->Name,Imyaman[k]);
        k=rand() % 8;
        strcpy(knigastr->Patr,Patrman[k]);
        k=rand() % 5;
        strcpy(knigastr->Izdat,izdatel[k]);
        k=rand() % 5;
        strcpy(knigastr->NameB,NameBook[k]);
        knigastr->god = rand() %213 + 1700;
        knigastr->nums = rand () %600 + 1;
        next(knigastr, first);
    }
    print(first);
    delete [] knigastr;
    getch();
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 06:53. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru