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

Структуры. Решение кода программы - C++

Восстановить пароль Регистрация
 
Владиславик
-131 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 139
31.10.2013, 13:10     Структуры. Решение кода программы #1
Пожалуйста, помогите написать код к программе.
-Задача-
В столовой предлагаются N комплексных обедов из Q блюд. Известна стоимость и калорийность каждого блюда. Сколько стоит самый дешевый и самый дорогой обед? Сколько калорий включает в себя самое калорийное блюдо?
-Мое предположение, как нужно решить задачу на С++
В консоли программа должна выводить следующие строки, а пользователь с клавиатуры вводит значение
Введите количество обедов (N):
Введите количество блюд (Q):
Введите стоимость (S):
Введите калорийность (K):
-Тут делается подсчет-
Самый дешевый обед:
Самы
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
egor2116
 Аватар для egor2116
337 / 368 / 42
Регистрация: 20.01.2013
Сообщений: 1,100
31.10.2013, 13:11     Структуры. Решение кода программы #2
Ну вот вы её решили осталось написать.
Владиславик
-131 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 139
31.10.2013, 13:17  [ТС]     Структуры. Решение кода программы #3
Пожалуйста, помогите написать код к программе.
-Задача-
В столовой предлагаются N комплексных обедов из Q блюд. Известна стоимость и калорийность каждого блюда. Сколько стоит самый дешевый и самый дорогой обед? Сколько калорий включает в себя самое калорийное блюдо?
-Мое предположение, как нужно решить задачу на С++
В консоли программа должна выводить следующие строки, а пользователь с клавиатуры вводит значение
Введите количество обедов (N):
Введите количество блюд (Q):
Введите стоимость (S):
Введите калорийность (K):
-Тут делается подсчет-
Самый дешевый обед:
Самый дорогой обед:
Самое калорийное блюдо:

-Как должен выполняться код программы-
Сначала введем количество обедов. После количество блюд.
Стоимость блюд формируется по массиву (в зависимости от колл. обедов(N=10, значит нужно ввести стоимость 10 блюд A[1] и т.д))
Ввод калорийности зависит от числа блюд(тут тоже формируется массив 10 блюд и вводится калорийность каждого блюда).
-Нахождение самого дешевого обеда формируется методом сравнения введенного массива стоимости.
Формирование самого дорогого и калорийного тем же методом.
-
Пожалуйста, помогите написать код, буду очень благодарен

Добавлено через 23 секунды
egor2116, пожалуйста, помогите написать код на С++
egor2116
 Аватар для egor2116
337 / 368 / 42
Регистрация: 20.01.2013
Сообщений: 1,100
31.10.2013, 13:21     Структуры. Решение кода программы #4
Могу предложить начало
что то типа этого

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
struct Dish
{
     float cash;
     unsigned int cal;
};
 
int main()
{
  unsigned int count_break=0;
  std::cout << "Enter counted breakfast :"; std::cin >> count_break;
  Dish * dishs = new Dish[count_break];
 
  for(int i=0; i<count_break; ++i)
  {
     std::cout << "Enter cash :"; std::cin >> dishs[i].cash; std::cout << std::endl;
     std::cout << "Enter cal   :"; std::cin >> dishs[i].cal; std::cout << std::endl;
  }
 
  //Вам осталось определить самый дешевый и самый дорогой ,и самый коллорийный обед
 
  delete [] dishs;
}
будут трудности задавайте вопросы.
Владиславик
-131 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 139
31.10.2013, 13:45  [ТС]     Структуры. Решение кода программы #5
egor2116, спасибо, но я пробовал, нужен полностью код. Пожалуйста, вы можете напечатать?
egor2116
 Аватар для egor2116
337 / 368 / 42
Регистрация: 20.01.2013
Сообщений: 1,100
31.10.2013, 14:40     Структуры. Решение кода программы #6
На глаз где то так

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
#include <iostream>
 
struct Dish
{
     float cash;
     unsigned int cal;
};
 
float getMaxCash(Dish ** d, unsigned int size1, unsigned int size2)
{
   float max=0.0f;
   float sum=0.0f;
   float * tmp1 = new float[size1];
   
   for(int i=0; i<size1; ++i)
       for(int j=0; j<size2; ++j)
         tmp1[i]+=d[i][j].cash;
         
    for(int i=0; i<size1; ++i)
       if(max<tmp1[i])
           max=tmp1[i];
           
   delete [] tmp1;   
   tmp1 = NULL;         
   return max;
}
 
float getMinCash(Dish ** d, unsigned int size1, unsigned int size2)
{
   float min=0.0f;
   float sum=0.0f;
   float * tmp2 = new float[size1];
   
   for(int i=0; i<size1; ++i)
       for(int j=0; j<size2; ++j)
         tmp2[i]+=d[i][j].cash;
         
     min=tmp2[0];
    for(int i=0; i<size1; ++i)
       if(min>tmp2[i])
           min=tmp2[i];
           
   delete [] tmp2; 
   tmp2 = NULL;           
   return min;
}
 
float getMaxCal(Dish ** d, unsigned int size1, unsigned int size2)
{
   unsigned int max=0;
   unsigned int sum=0;
   unsigned int * tmp3 = new unsigned int[size1];
    
    for(int i=0; i<size1; ++i)
       for(int j=0; j<size2; ++j)
         tmp3[i]+=d[i][j].cal;
     
         
    for(int i=0; i<size1; ++i)
    std::cout<<tmp3[i]<< " "; 
       if(max<tmp[i])
           max=tmp[i];
           
   delete [] tmp3;   
   tmp3 = NULL;         
   return max;
}
 
int main()
{
  unsigned int count_break=0;
  unsigned int count_dishs=0;
  std::cout << "Enter counted breakfast :"; std::cin >> count_break;
  std::cout << "Enter counted dishs     :"; std::cin >> count_dishs;
  
  Dish ** dishs = new Dish*[count_break];
  for(int i=0; i<count_break; ++i)
        dishs[i]=new Dish[count_dishs];
        
  for(int i=0; i<count_break; ++i)
  {
    std::cout << "Enter breakfast # " << i+1 << std::endl; 
      for(int j=0; j<count_dishs; ++j)
      {
         std::cout << "Enter cash :"; std::cin >> dishs[i][j].cash; std::cout << std::endl;
         std::cout << "Enter cal   :"; std::cin >> dishs[i][j].cal; std::cout << std::endl;
      }
}
  
  std::cout << "Max cost = " << getMaxCash(dishs, count_break, count_dishs) << std::endl;
  std::cout << "Min cost = " << getMinCash(dishs, count_break, count_dishs) << std::endl;
  std::cout << "Max calories  = " << getMaxCal(dishs, count_break, count_dishs) << std::endl;
 
  
 for(int i=0; i<count_break; ++i)
      delete dishs[i];
      delete [] dishs;
 
system("PAUSE");
return 0;
}
Владиславик
-131 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 139
31.10.2013, 14:50  [ТС]     Структуры. Решение кода программы #7
egor2116, спасибо программу проверил, она ругается, т.к найдена ошибка, можете помочь исправить ошибки?
egor2116
 Аватар для egor2116
337 / 368 / 42
Регистрация: 20.01.2013
Сообщений: 1,100
31.10.2013, 14:58     Структуры. Решение кода программы #8
программу проверил, она ругается, т.к найдена ошибка, можете помочь исправить ошибки?
Извините писал на глаз. Сейчас на роботе и нет компилятора под рукой.

А на что ругается ? Текст ошибки.

Добавлено через 4 минуты
Кажется нашел. Замените на эту функцию.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
float getMaxCal(Dish ** d, unsigned int size1, unsigned int size2)
{
   unsigned int max=0;
   unsigned int sum=0;
   unsigned int * tmp3 = new unsigned int[size1];
    
    for(int i=0; i<size1; ++i)
       for(int j=0; j<size2; ++j)
         tmp3[i]+=d[i][j].cal;
     
         
    for(int i=0; i<size1; ++i)
       if(max<tmp3[i])
           max=tmp3[i];
           
   delete [] tmp3;   
   tmp3 = NULL;         
   return max;
}
Владиславик
-131 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 139
31.10.2013, 15:45  [ТС]     Структуры. Решение кода программы #9
egor2116, сейчас протестим

Добавлено через 44 секунды
egor2116, получается в коде все функции заменить на ту, которую вы скинули?

Добавлено через 15 минут
Код
warning C4018: <: несоответствие типов со знаком и без знака
warning C4018: <: несоответствие типов со знаком и без знака
warning C4018: <: несоответствие типов со знаком и без знака
warning C4018: <: несоответствие типов со знаком и без знака
warning C4018: <: несоответствие типов со знаком и без знака
warning C4018: <: несоответствие типов со знаком и без знака
warning C4018: <: несоответствие типов со знаком и без знака
warning C4018: <: несоответствие типов со знаком и без знака
warning C4018: <: несоответствие типов со знаком и без знака
error C2065: tmp: необъявленный идентификатор
error C2065: i: необъявленный идентификатор
error C2065: tmp: необъявленный идентификатор
error C2065: i: необъявленный идентификатор
warning C4244: return: преобразование "unsigned int" в "float", возможна потеря данных
warning C4018: <: несоответствие типов со знаком и без знака
warning C4018: <: несоответствие типов со знаком и без знака
warning C4018: <: несоответствие типов со знаком и без знака
 warning C4018: <: несоответствие типов со знаком и без знака
Добавлено через 18 секунд
egor2116, вот такие ошибки выдает программа
egor2116
 Аватар для egor2116
337 / 368 / 42
Регистрация: 20.01.2013
Сообщений: 1,100
31.10.2013, 16:33     Структуры. Решение кода программы #10
Замените
C++
1
float getMaxCal(Dish ** d, unsigned int size1, unsigned int size2)
на
C++
1
unsigned int getMaxCal(Dish ** d, unsigned int size1, unsigned int size2)
egor2116, получается в коде все функции заменить на ту, которую вы скинули?
не все а только на ту которой соответствует имя getMaxCal
Владиславик
-131 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 139
31.10.2013, 17:05  [ТС]     Структуры. Решение кода программы #11
egor2116, спасибо. сейчас помозгую

Добавлено через 6 минут
Получается, код должен получится таким?
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
#include "stdafx.h"
#include <iostream>
 
struct Dish
{
     float cash;
     unsigned int cal;
};
 
unsigned int getMaxCal(Dish ** d, unsigned int size1, unsigned int size2)
 
{
   unsigned int max=0;
   unsigned int sum=0;
   unsigned int * tmp3 = new unsigned int[size1];
    
    for(int i=0; i<size1; ++i)
       for(int j=0; j<size2; ++j)
         tmp3[i]+=d[i][j].cal;
     
         
    for(int i=0; i<size1; ++i)
       if(max<tmp3[i])
           max=tmp3[i];
           
   delete [] tmp3;   
   tmp3 = NULL;         
   return max;
}
 
unsigned int getMaxCal(Dish ** d, unsigned int size1, unsigned int size2)
 
{
   unsigned int max=0;
   unsigned int sum=0;
   unsigned int * tmp3 = new unsigned int[size1];
    
    for(int i=0; i<size1; ++i)
       for(int j=0; j<size2; ++j)
         tmp3[i]+=d[i][j].cal;
     
         
    for(int i=0; i<size1; ++i)
       if(max<tmp3[i])
           max=tmp3[i];
           
   delete [] tmp3;   
   tmp3 = NULL;         
   return max;
}
 
unsigned int getMaxCal(Dish ** d, unsigned int size1, unsigned int size2)
 
{
   unsigned int max=0;
   unsigned int sum=0;
   unsigned int * tmp3 = new unsigned int[size1];
    
    for(int i=0; i<size1; ++i)
       for(int j=0; j<size2; ++j)
         tmp3[i]+=d[i][j].cal;
     
         
    for(int i=0; i<size1; ++i)
       if(max<tmp3[i])
           max=tmp3[i];
           
   delete [] tmp3;   
   tmp3 = NULL;         
   return max;
}
 
int main()
{
  unsigned int count_break=0;
  unsigned int count_dishs=0;
  std::cout << "Enter counted breakfast :"; std::cin >> count_break;
  std::cout << "Enter counted dishs     :"; std::cin >> count_dishs;
  
  Dish ** dishs = new Dish*[count_break];
  for(int i=0; i<count_break; ++i)
        dishs[i]=new Dish[count_dishs];
        
  for(int i=0; i<count_break; ++i)
  {
    std::cout << "Enter breakfast # " << i+1 << std::endl; 
      for(int j=0; j<count_dishs; ++j)
      {
         std::cout << "Enter cash :"; std::cin >> dishs[i][j].cash; std::cout << std::endl;
         std::cout << "Enter cal   :"; std::cin >> dishs[i][j].cal; std::cout << std::endl;
      }
}
  
  std::cout << "Max cost = " << getMaxCash(dishs, count_break, count_dishs) << std::endl;
  std::cout << "Min cost = " << getMinCash(dishs, count_break, count_dishs) << std::endl;
  std::cout << "Max calories  = " << getMaxCal(dishs, count_break, count_dishs) << std::endl;
 
  
 for(int i=0; i<count_break; ++i)
      delete dishs[i];
      delete [] dishs;
 
system("PAUSE");
return 0;
}
Добавлено через 1 минуту
egor2116, программка ругается на эти строки
C++
1
2
 std::cout << "Max cost = " << getMaxCash(dishs, count_break, count_dishs) << std::endl;
  std::cout << "Min cost = " << getMinCash(dishs, count_break, count_dishs) << std::endl;
Якобы getMaxCash и getMinCash не определены.
egor2116
 Аватар для egor2116
337 / 368 / 42
Регистрация: 20.01.2013
Сообщений: 1,100
31.10.2013, 17:16     Структуры. Решение кода программы #12
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
#include <iostream>
 
struct Dish
{
     float cash;
     unsigned int cal;
};
 
float getMaxCash(Dish ** d, unsigned int size1, unsigned int size2)
{
   float max=0.0f;
   float sum=0.0f;
   float * tmp1 = new float[size1];
   
   for(int i=0; i<size1; ++i)
       for(int j=0; j<size2; ++j)
         tmp1[i]+=d[i][j].cash;
         
    for(int i=0; i<size1; ++i)
       if(max<tmp1[i])
           max=tmp1[i];
           
   delete [] tmp1;   
   tmp1 = NULL;         
   return max;
}
 
float getMinCash(Dish ** d, unsigned int size1, unsigned int size2)
{
   float min=0.0f;
   float sum=0.0f;
   float * tmp2 = new float[size1];
   
   for(int i=0; i<size1; ++i)
       for(int j=0; j<size2; ++j)
         tmp2[i]+=d[i][j].cash;
         
     min=tmp2[0];
    for(int i=0; i<size1; ++i)
       if(min>tmp2[i])
           min=tmp2[i];
           
   delete [] tmp2; 
   tmp2 = NULL;           
   return min;
}
 
unsigned int getMaxCal(Dish ** d, unsigned int size1, unsigned int size2)
 
{
   unsigned int max=0;
   unsigned int sum=0;
   unsigned int * tmp3 = new unsigned int[size1];
    
    for(int i=0; i<size1; ++i)
       for(int j=0; j<size2; ++j)
         tmp3[i]+=d[i][j].cal;
     
         
    for(int i=0; i<size1; ++i)
       if(max<tmp3[i])
           max=tmp3[i];
           
   delete [] tmp3;   
   tmp3 = NULL;         
   return max;
}
 
int main()
{
  unsigned int count_break=0;
  unsigned int count_dishs=0;
  std::cout << "Enter counted breakfast :"; std::cin >> count_break;
  std::cout << "Enter counted dishs     :"; std::cin >> count_dishs;
  
  Dish ** dishs = new Dish*[count_break];
  for(int i=0; i<count_break; ++i)
        dishs[i]=new Dish[count_dishs];
        
  for(int i=0; i<count_break; ++i)
  {
    std::cout << "Enter breakfast # " << i+1 << std::endl; 
      for(int j=0; j<count_dishs; ++j)
      {
         std::cout << "Enter cash :"; std::cin >> dishs[i][j].cash; std::cout << std::endl;
         std::cout << "Enter cal   :"; std::cin >> dishs[i][j].cal; std::cout << std::endl;
      }
}
  
  std::cout << "Max cost = " << getMaxCash(dishs, count_break, count_dishs) << std::endl;
  std::cout << "Min cost = " << getMinCash(dishs, count_break, count_dishs) << std::endl;
  std::cout << "Max calories  = " << getMaxCal(dishs, count_break, count_dishs) << std::endl;
 
  
 for(int i=0; i<count_break; ++i)
      delete dishs[i];
      delete [] dishs;
 
system("PAUSE");
return 0;
}
Владиславик
-131 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 139
31.10.2013, 17:40  [ТС]     Структуры. Решение кода программы #13
egor2116, все, я проверил. Спасибо большое.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
01.11.2013, 21:43     Структуры. Решение кода программы
Еще ссылки по теме:

C++ Решение задач Р. Лафоре, структуры
C++ Создание структуры программы
Структуры. Ошибки в работе программы C++

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

Или воспользуйтесь поиском по форуму:
Владиславик
-131 / 0 / 0
Регистрация: 28.10.2013
Сообщений: 139
01.11.2013, 21:43  [ТС]     Структуры. Решение кода программы #14
egor2116, программа не корректно считает максимальную и минимальную цену и максимальную калорийность. Помогите исправить, пожалуйста
Скриншот выполнения программы-
Вложение 324066
Yandex
Объявления
01.11.2013, 21:43     Структуры. Решение кода программы
Ответ Создать тему
Опции темы

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