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

Работа с файлами - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Задача про ранец http://www.cyberforum.ru/cpp-beginners/thread243347.html
Помогите решить задачу на С Есть вес предметов и ценность, а также есть максимальный вес, который можно загрузить в ранец! Необходимо заполнить ранец так, чтобы стоимость предметов была максимальной и вес не привышал максимальный вес, который можно загрузить в ранец! Спасибо! Буду очень благодарна!
C++ Структуры 1-решить задачу, используя структуру point для хранения координат точки : Наийти три разлинные точки из заданного множества точек, образющих треугольник наибольшего периметра. 2-Решить задачу, используя структуру содержащую члены-данные и члены функции На основе данных входного файла составить список студентов, включающий фамилмю, факультет, курс, группу, 5 оценок.Вывести в новый файл... http://www.cyberforum.ru/cpp-beginners/thread243342.html
C++ Корни квадратного уравнения,массив и среднее арифметическое
1.Вычислить корни квадратного уравнения ax^2+bx+c=0. 2.Вычислить сумму и количество положительных элементов массива X.X-действительные числа. 3.Найти среднее арифметическое значений функции f(x) в точках a, b, (a+b)/2 используя обращение к функции f=(x*sin⁡ π/4) / (1-2x*(cos⁡ π)/4+x^2).
Решить с оператором while C++
помогите пожалуйста решить прогу, используя в прогрумме оператор while. Условие:Пасажирский самолет может поднять груз общим весом 30тон. Составить программу для определения веса почтового груза, который может поместить в самолет после пасадки пассажиров и загрузки их багажа. Во время регистрации пасажиров ЭВМ должна считывать колличество пасажиров(условный вес одного человека 100 кг.) ...
C++ Число Фибоначчи, циклы. http://www.cyberforum.ru/cpp-beginners/thread243315.html
Прошу помочь с решением... Нужно сформировать все числа Фибоначчи не превышающие заданное число. Заранее спасибо..
C++ Циклы Прошу помочь с решением задачек, заранее благодарен ;) 1. Дана последовательность из n целых чисел. Найти сумму минимального и максимального элементов в этой последовательности. 2. Дана последовательность целых чисел, за которой следует 0. Найти количество элементов этой последовательности, кратных числу К. подробнее

Показать сообщение отдельно
lemegeton
2923 / 1352 / 135
Регистрация: 29.11.2010
Сообщений: 2,725
15.02.2011, 21:56
Лажа какая-то получилась, но на С, просто, и однофамильцев читает.
В текстовом файле должны быть записи по одной строке на строчку
Код
Имя
Фамилия
Класс
Имя
Фамилия
Класс
...
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
#include <stdio.h>
#include <string.h>
#include <stddef.h>
#include <stdlib.h>
 
struct Student {
  char *name;
  char *surname;
  char *class_name;
};
 
struct StudentList {
  struct Student *students;
  size_t size;
  size_t capacity;
};
 
const k_recapacity = 1024;
void AddStudent(struct Student student, struct StudentList *student_list) {
  if (student_list->capacity == 0 && student_list->students == NULL) {
    student_list->students = (struct Student*)malloc(sizeof(struct Student) *
                             (student_list->capacity += k_recapacity));
  } else
  if (student_list->size == student_list->capacity) {
    struct Student *new_data = (struct Student*)malloc(sizeof(struct Student) *
                               (student_list->capacity + k_recapacity));
    int i;
    for (i = 0; i < student_list->size; ++i)
      new_data[i] = student_list->students[i];
    free(student_list->students);
    student_list->students = new_data;
    student_list->capacity += k_recapacity;
  }
  student_list->students[student_list->size++] = student;
}
void ClearStudents(struct StudentList *student_list) {
  int i;
  for (i = 0; i < student_list->size; ++i) {
    free(student_list->students[i].name);
    free(student_list->students[i].surname);
    free(student_list->students[i].class_name);
  }
  free(student_list->students);
  student_list->students = NULL;
  student_list->size = 0;
  student_list->capacity = 0;
}
 
int ReadString(char **destination, char *buffer, size_t buffer_size,
                FILE *infile) {
  int result = 0;
  if (result = (fgets(buffer, buffer_size, infile) != NULL)) {
    size_t buffer_length = strlen(buffer);
    if (buffer_length > 0) buffer[buffer_length - 1] = '\0';
    *destination = strcpy((char*)malloc(buffer_length + 1), buffer);
  } else {
    *destination = NULL;
  }
  return result;
}
 
int main(int argc, char *argv[]) {
  size_t buffer_size = 65536;
  FILE *infile = fopen("tutor36.c.txt", "r");
  struct StudentList student_list = { NULL, 0, 0 };
  if (infile == NULL) {
    printf("Could not open stream.\n");
  } else {
    char *buffer = (char*)malloc(buffer_size);
    while (!feof(infile)) {
      struct Student new_student = {NULL, NULL, NULL};
      if (ReadString(&new_student.name, buffer, buffer_size, infile) &&
          ReadString(&new_student.surname, buffer, buffer_size, infile) &&
          ReadString(&new_student.class_name, buffer, buffer_size, infile)) {
        AddStudent(new_student, &student_list);
      } else {
        fprintf(stderr, "Unexpected end of file.\n");
      }
    }
    free(buffer);
  }
 
  int i;
  for (i = 0; i < student_list.size - 1; ++i) {
    int j;
    for (j = i + 1; j < student_list.size; ++j)
      if (strcmp(student_list.students[i].surname,
          student_list.students[j].surname) == 0)
        printf("%s %s in %s has %s %s in %s.\n",
                               student_list.students[i].name,
                               student_list.students[i].surname,
                               student_list.students[i].class_name,
                               student_list.students[j].name,
                               student_list.students[j].surname,
                               student_list.students[j].class_name);
  }
 
  ClearStudents(&student_list);
  return 0;
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru