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

Изучить и освоить приёмы разработки программ с использованием структур - C++

Восстановить пароль Регистрация
 
ZZnerzuL
0 / 0 / 0
Регистрация: 10.12.2012
Сообщений: 3
16.12.2012, 16:15     Изучить и освоить приёмы разработки программ с использованием структур #1
Сформировать документ, в котором хранится информация о заболеваниях сотрудников: ФИО, год рождения, заболевание, продолжительность болезни. На его основе сформи¬ровать список сотрудников, которые перенесли одно и тоже заболевание. помогите плз
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.12.2012, 16:15     Изучить и освоить приёмы разработки программ с использованием структур
Посмотрите здесь:

C++ Разработка и отладка алгоритмов и программ с использованием структур данных.
Научиться работать с векторными данными языка «С»: структурами и объединениями. Изучить правила объявления структур и объединений, обращение к их полям, построение вложенных векторных типов данных. C++
C++ Лаба. Тема: Разработка и отладка алгоритмов и программ с использованием динамических структур.
Программирование с использованием структур C++
C++ Составление программ на использование структур данных
C++ Какие книги лучше всего изучить чтобы хорошо изучить с++
C++ Программирование с использованием структур
Програмирование с использованием структур C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
lemegeton
 Аватар для lemegeton
2910 / 1339 / 133
Регистрация: 29.11.2010
Сообщений: 2,720
16.12.2012, 18:54     Изучить и освоить приёмы разработки программ с использованием структур #2
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
#include <cstdlib>
#include <ctime>
#include <string>
#include <iostream>
#include <iomanip>
 
struct MedicalRecord {
  std::string name;
  int birthYear;
  std::string disease;
  int duration;  
};
 
std::string getRandomName() {
  static const std::string names[] = {"Ivan", "Petr", "Ilya", "Sergey", "Alexander", "Stepan"};
  static const std::string surnames[] = {"Ivanov", "Petrov", "Sidorov", "Orlov", "Sokolov", "Ilyin", "Sergeyev", "Alexandrov", "Sidorov" };
  static const size_t namesSize = sizeof(names) / sizeof(std::string);
  static const size_t surnamesSize = sizeof(surnames) / sizeof(std::string);    
  return names[rand() % namesSize] + " " + surnames[rand() % surnamesSize];
};
 
std::string getRandomDisease() {
  static const std::string diseases[] = {"flu", "cold", "hepatitis", "enterovirus"};
  static const size_t numberOfDiseases = sizeof(diseases) / sizeof(std::string);
  return diseases[rand() % numberOfDiseases];
};
 
MedicalRecord getRandomMedicalRecord() {
  MedicalRecord result;
  result.name = getRandomName();
  result.birthYear = 1980 + rand() % 10;
  result.disease = getRandomDisease();
  result.duration = 2 + rand() % 4;
  return result;
};
 
std::ostream &operator<<(std::ostream &stream, const MedicalRecord &medicalRecord) {
  return stream << "MedicalRecord {" <<
    "name=" << medicalRecord.name <<
    ", birthYear=" << medicalRecord.birthYear <<
    ", disease=" << medicalRecord.disease <<
    ", duration=" << medicalRecord.duration <<
    "}";
};
 
template <class Iterator, class InsertIterator, class Predicate>
size_t copyIf(Iterator begin, Iterator end, InsertIterator destination, Predicate predicate) {
  size_t count = 0;
  while (begin != end) {
    if (predicate(*begin)) {
      *destination++ = *begin;
      ++count;
    }
    ++begin;
  }
  return count;
};
 
class DiseaseFilter {
 public:
  DiseaseFilter(const std::string &disease) : disease(disease) {}
  bool operator()(const MedicalRecord &medicalRecord) {
    return medicalRecord.disease == disease;
  }
 private:
  std::string disease;
};
 
int main(int argc, char *argv[]) {
  setlocale(LC_ALL,"rus");
  srand(time(0));
 
  size_t numberOfMedicalRecords = 20 + rand() % 5;
  MedicalRecord *medicalRecords = new MedicalRecord[numberOfMedicalRecords];
 
  std::cout << "Disease records:" << std::endl;
  for (int i = 0; i < numberOfMedicalRecords; ++i)
    std::cout << (medicalRecords[i] = getRandomMedicalRecord()) << std::endl;
  
  MedicalRecord *fluRecords = new MedicalRecord[numberOfMedicalRecords];
  size_t numberOfFluRecords = copyIf(medicalRecords, medicalRecords + numberOfMedicalRecords,
    fluRecords, DiseaseFilter("flu"));
  
  std::cout << "They got flu:" << std::endl;
  for (int i = 0; i < numberOfFluRecords; ++i)
    std::cout << fluRecords[i] << std::endl;
  
  delete [] fluRecords;
  delete [] medicalRecords;
  std::cin.get();
}
Добавлено через 21 секунду
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
#include <cstdlib>
#include <ctime>
#include <string>
#include <iostream>
#include <iomanip>
 
struct MedicalRecord {
  std::string name;
  int birthYear;
  std::string disease;
  int duration;  
};
 
std::string getRandomName() {
  static const std::string names[] = {"Ivan", "Petr", "Ilya", "Sergey", "Alexander", "Stepan"};
  static const std::string surnames[] = {"Ivanov", "Petrov", "Sidorov", "Orlov", "Sokolov", "Ilyin", "Sergeyev", "Alexandrov", "Sidorov" };
  static const size_t namesSize = sizeof(names) / sizeof(std::string);
  static const size_t surnamesSize = sizeof(surnames) / sizeof(std::string);    
  return names[rand() % namesSize] + " " + surnames[rand() % surnamesSize];
};
 
std::string getRandomDisease() {
  static const std::string diseases[] = {"flu", "cold", "hepatitis", "enterovirus"};
  static const size_t numberOfDiseases = sizeof(diseases) / sizeof(std::string);
  return diseases[rand() % numberOfDiseases];
};
 
MedicalRecord getRandomMedicalRecord() {
  MedicalRecord result;
  result.name = getRandomName();
  result.birthYear = 1980 + rand() % 10;
  result.disease = getRandomDisease();
  result.duration = 2 + rand() % 4;
  return result;
};
 
std::ostream &operator<<(std::ostream &stream, const MedicalRecord &medicalRecord) {
  return stream << "MedicalRecord {" <<
    "name=" << medicalRecord.name <<
    ", birthYear=" << medicalRecord.birthYear <<
    ", disease=" << medicalRecord.disease <<
    ", duration=" << medicalRecord.duration <<
    "}";
};
 
template <class Iterator, class InsertIterator, class Predicate>
size_t copyIf(Iterator begin, Iterator end, InsertIterator destination, Predicate predicate) {
  size_t count = 0;
  while (begin != end) {
    if (predicate(*begin)) {
      *destination++ = *begin;
      ++count;
    }
    ++begin;
  }
  return count;
};
 
class DiseaseFilter {
 public:
  DiseaseFilter(const std::string &disease) : disease(disease) {}
  bool operator()(const MedicalRecord &medicalRecord) {
    return medicalRecord.disease == disease;
  }
 private:
  std::string disease;
};
 
int main(int argc, char *argv[]) {
  setlocale(LC_ALL,"rus");
  srand(time(0));
 
  size_t numberOfMedicalRecords = 20 + rand() % 5;
  MedicalRecord *medicalRecords = new MedicalRecord[numberOfMedicalRecords];
 
  std::cout << "Disease records:" << std::endl;
  for (int i = 0; i < numberOfMedicalRecords; ++i)
    std::cout << (medicalRecords[i] = getRandomMedicalRecord()) << std::endl;
  
  MedicalRecord *fluRecords = new MedicalRecord[numberOfMedicalRecords];
  size_t numberOfFluRecords = copyIf(medicalRecords, medicalRecords + numberOfMedicalRecords,
    fluRecords, DiseaseFilter("flu"));
  
  std::cout << "They got flu:" << std::endl;
  for (int i = 0; i < numberOfFluRecords; ++i)
    std::cout << fluRecords[i] << std::endl;
  
  delete [] fluRecords;
  delete [] medicalRecords;
  std::cin.get();
}
Yandex
Объявления
16.12.2012, 18:54     Изучить и освоить приёмы разработки программ с использованием структур
Ответ Создать тему
Опции темы

Текущее время: 00:32. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru