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

Создать указатель на структуру - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Как получить ссылку на указатель или указатель на указатель в массиве? http://www.cyberforum.ru/cpp-beginners/thread1031672.html
В процессе реализации сортировки пузырьком натолкнулся на такую проблему: как поменять значения указателей, передаваемых в функцию. Если задать указатели прямо, то можно поменять их значения и по ссылке и по указателю на указатель: void Swap1(char** first, char** second ){ char* temp = *first; *first = *second; *second = temp; } void Swap2(char* &first, char* &second ) { char* temp...
C++ класс для создания календаря помогите пожалуйста создать класс для определения дня недели по календарной дате. Дата – три целых числа: число, месяц, год. Диапазон дат – по меньшей мере, два тысячелетия. (Демонстрация применения) http://www.cyberforum.ru/cpp-beginners/thread1031633.html
Система счисления C++
Когда делиться а когда умножаются при переводе из одной системы счисления в другую.
C++ Структура
Мне дана вот такая задача написать программу на : Пункт обмена валюты состоит из таких элементов как : имя точки обмена валюты, курс покупки, курс продажи, адрес пункта, а также телефона. Надо найти адрес пункта который объявил самый низкий курс продажи, телефон пункта и наименование пункта. Возможные варианты 1 наверно надо вывести это на текстовый документ 2 или же на консольном...
C++ Поиск совершенного числа в массиве http://www.cyberforum.ru/cpp-beginners/thread1031605.html
Необходимо найти в массиве все совершенные числа в диапазоне от n1 до n2. Будем учитывать, что массив уже заполнен. //задаём диапазон исследуемых элементов cout<<"Введите n1 = "; cin>>n1; cout<<"Введите n2 = "; cin>>n2; //находим совершенные числа int x; for(i = mas; i <= mas; n1++){
C++ Считать длину строки текстового файла Есть квадратная матрица, которая заполняется данными из файла. Если размерность матрицы больше, чем объём данных в файле, то нужно заполнить недостающие элементы матрицы случайными числами. Пытаюсь сделать так:cout<<"Введите размерность квадартной матрицы: "; cin>>s; int **mas = new int*; ifstream fs; fs.open("input.txt"); int a = fs.getline; if(s > a){ for(i = a + 1; i < s; i++) подробнее

Показать сообщение отдельно
ПерС
366 / 282 / 84
Регистрация: 05.11.2013
Сообщений: 806
Записей в блоге: 5
Завершенные тесты: 1
07.12.2013, 11:39     Создать указатель на структуру
Вот это у меня работало, только обычный Си, а на "плюсы", и сортировали студентов, а не продукцию, и функция показа списка называлась show
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
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <string.h>
#define MAX 30
 
typedef struct student {
 unsigned char f[MAX]; //Фамилия
 int ekz[4]; //4 оценки
 student *next; //Указатель на следующего студента
};
 
int show (student *head) {
 //Показать список, начиная с эл. head и вернуть кол-во записей
 int count=0;
 while (1) {
  printf ("\n%s",head->f);
  for (int i=0; i<4; i++) printf (" %d",head->ekz[i]);
  count++;
  if (!head->next) break;
  head=head->next;
 }
 return count;
}
 
student *sort (student *ph) {
 //Сортируем список по алфавиту (фамилии, полю f) и возвращаем
 //указатель на начало измененного списка
 student *q,*out=NULL,*p,*pr; //out - выход - сначала пуст
 while (ph !=NULL) { //пока не конец входного списка
  q = ph; ph = ph->next; //исключить очередной элемент
  for (p=out,pr=NULL; p!=NULL && strcmp(q->f,p->f)>0; pr=p,p=p->next);
   //ищем, куда включить очередной элемент - тут strcmp
   //задает критерий сравнения элементов, в вашей задаче м.б. другой
  if (pr==NULL) { q->next=out; out=q; } //включение в начало
  else { q->next=p; pr->next=q; } //или после предыдущего
 }
 return out;
}
 
void main () {
 student group[] = { //В начале фамилии в списке расставлены как в массиве -
  //предыдущий элемент показывает на следующий
  {"Popov",{4,4,3,3},&group[1]},
  {"Belugin",{4,5,3,5},&group[2]},
  {"Ivanov",{4,4,5,5},&group[3]},
  {"Yakovlev",{5,4,3,2},&group[4]},
  {"Petrov",{5,5,5,5},NULL}
 };
 printf ("\nИсходный список:");
 int count=show (&group[0]);
 printf ("\nВсего записей: %d",count);
 //Сортируем список структур по алфавиту
 student *ptr=sort (group);
 printf ("\nОтсортированный список:");
 show (ptr);
 getchar();
}
 
Текущее время: 06:39. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru