Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
zmei87
0 / 0 / 0
Регистрация: 27.10.2013
Сообщений: 10
#1

Не могу доработать программу - C++

29.10.2013, 21:45. Просмотров 387. Ответов 10
Метки нет (Все метки)

Вообщем такое задание :Описать структуру с именем Order, содержащую следующие поля: plat-расчетный счет плательщика, pol- расчетный счет получателя, summa-перечисляемая сумма. Написать программу, выполняющую ввод с клавиатуры данных в массив Spisok, состоящий из 15 элементов типа Order. Записи должны быть упорядочены по расчетным счетам плательщиков. Вывести на экран информацию о сумме, снятой с расчетного счета плательщика, введенного с клавиатуры. Если такого расчетного счета нет, то вывести соответствующее сообщение.

мой код
Код
#include <cstdlib>
#include <iostream>
 
using namespace std;
 
int main()
{
    int const n=20;
struct order {
       char plat[n],pol[n]; // Здесь я обозначил счета, длинной 20 символов. 
       float summa;
};
 order tmp;
 order Spisok[15];
 int nomer_plat;
 bool r=false;
 float snyataya_summa=0;
    for (int i=0;i<=14;i++)
     { cout<<"Platel'shik - ";
        cin>>Spisok[i].plat;
        cout<<"Poluchatel - ";
        cin>>Spisok[i].pol;
        cout<<"summa - ";
        cin>>Spisok[i].summa;     
     }          
for (int j=0;j<=14;j++)
        for (int i=1;i<=14;i++)
            {                               //в такой форме оператор if  не может использовать массивы, нужно немного подделать программу, использовать можно strcmp.
             if (Spisok[i].plat < Spisok[i-1].plat)
                { 
                  tmp=Spisok[i-1];
                  Spisok[i-1]=Spisok[i];
                  Spisok[i]=tmp;   
                }
            }
   for (int i=0;i<=14;i++)
   cout<<"Platel'shik "<<Spisok[i].plat<<" Poluchatel' "<<Spisok[i].pol<<" summa "<<Spisok[i].summa<<"\n";
   cout<<"Vvedite nomer raschetnogo scheta\n";
   cin>>nomer_plat; 
   for (int i=0;i<=14;i++)                  
       if (Spisok[i].plat == nomer_plat)  //такая же ситуация, поиск не происхоодит.
          {
             snyataya_summa+=Spisok[i].summa;
             r=true;                   
          }
   if (r==true)
      cout<<"S raschetnogo scheta "<<nomer_plat<<" snyato "<<snyataya_summa<<"\n";
   else
       cout<<"Takogo scheta ne sushestvuet\n";           
    system("PAUSE");
    return EXIT_SUCCESS;
}
Помогите,пожалуйста
1)сортировку настроить.
2)настроить вывод на экран суммы введённого с клавиатуры счёта плательщика.
+ что-то испоганил и начал выдавать ошибку 'Cannot convert int to char'
Помогите, разобраться
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.10.2013, 21:45
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Не могу доработать программу (C++):

не могу закончить программу. основу (как я считаю) я написала. доработать не получается - C++
уменьшить элементы столбца на величину их индекса. вывести на экран сумму нечетных элементов в столбце. промежуточная функция: выполнить...

Вывод в текстовый файл, не могу доработать (код + пояснения) - C++
Собственно задание - Создать класс для вычисления значения функции y=aSin(x+b), на произвольном интервале с произвольным шагом, результат...

Доработать программу - C++
Найти сумму ряда с точностью е=10^-3 ,общий член которого An = (-1)^n-1/n^n Тут надо дописать нужные библиотеки и концовку дописать ...

доработать программу - C++
что изменить в коде, чтобы значения вводились не с клавиатуры, а читались из файла или хотя бы вводились в самом коде? пробовал вводить в...

Доработать программу - C++
Как сюда добавить учет табуляции и переноса строки #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;fstream&gt; #include &lt;string&gt; ...

Доработать программу - C++
Помогите доработать программу-Даны натуральное n, целые числа a1, ..., an. Внутри данной последовательности могут быть поваторяющиеся...

10
Folko
265 / 253 / 7
Регистрация: 27.09.2013
Сообщений: 877
Записей в блоге: 1
29.10.2013, 22:11 #2
zmei87, а можно словами сказать, каким образом вы пытались реализовать сортировку и прочее. Я бы сделал класс с функцией сортировки
0
zmei87
0 / 0 / 0
Регистрация: 27.10.2013
Сообщений: 10
29.10.2013, 22:35  [ТС] #3
Цитата Сообщение от Folko Посмотреть сообщение
zmei87, а можно словами сказать, каким образом вы пытались реализовать сортировку и прочее. Я бы сделал класс с функцией сортировки
всмысле класс с функцией?
0
Folko
265 / 253 / 7
Регистрация: 27.09.2013
Сообщений: 877
Записей в блоге: 1
29.10.2013, 22:39 #4
zmei87, делаем класс spisok, в котором будет храниться и обрабатываться ваш список структур. Также в нем будут функции сортировки и вывода информации о конкретном абоненте (или кто там)
Пример:
C++
1
2
3
4
5
6
7
8
9
10
11
class spisok {
public:
spisok();
void sort();
void addElement(<данные нового элемента>);
void view(<имя нужного чела>);
private:
human* head;
int size;
human* end;
};
0
lemegeton
2925 / 1354 / 135
Регистрация: 29.11.2010
Сообщений: 2,725
29.10.2013, 22:47 #5
У вас очень много косяков. Начать с того, где закрывается функция main.

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
114
115
116
117
118
119
120
121
122
123
124
125
#include <iostream>
#include <string>
#include <algorithm>
 
class Account {
 public:
  Account(const std::string &id) : id(id) {}
  const std::string &getId() const {
    return id;
  }
 private:
  std::string id;
};
 
std::ostream &operator<<(std::ostream &stream, const Account &a) {
  return stream << "Account{" <<
    "id=\"" << a.getId() << "\"}";
}
 
bool operator==(const Account &a, const Account &b) {
  return a.getId() == b.getId();
}
 
bool operator<(const Account &a, const Account &b) {
  return a.getId() < b.getId();
}
 
class Order {
 public:
  Order(const Account &source, const Account &destination, int amount)
    : source(source), destination(destination), amount(amount) {}
  const Account &getSource() const {
    return source;
  }
  const Account &getDestination() const {
    return destination;
  }
  int getAmount() const {
    return amount;
  }
 private:
  Account source;
  Account destination;
  int amount;
};
 
int orderSourceComparator(const Order &a, const Order &b) {
  return a.getSource() < b.getSource() ? 1 :
    a.getSource() == b.getSource() ? 0 : -1;
}
 
std::ostream &operator<<(std::ostream &stream, const Order &o) {
  return stream << "Order{" <<
    "source=" << o.getSource() << ", " <<
    "destination=" << o.getDestination() << "}";
}
 
/**
 * Ищет аккаунт с указанным id.
 * 
 * @param id id аккаунта для поиска
 * @param first указатель на первый аккаунт  
 * @param last указатель на  аккаунт после последнего  
 * @return 0, если аккаунт не найден или указатель на аккаунт
 */ 
const Account *search(const std::string id, const Account *first,
  const Account *last) {
  while (first != last) {
    if (first->getId() == id) {
      return first;
    }
    ++first;
  }
  return 0;
}
 
int main(int, char**) {
  // заготовка
  // это все надо вводить, но мне лень
  Account accounts[] = { Account("000"), Account("111"), Account("222"),
    Account("333")};
  int numberOfAccounts = sizeof(accounts) / sizeof(accounts[0]);
  Order orders[] = { Order(accounts[0], accounts[2], 7),
    Order(accounts[1], accounts[0], 5),
    Order(accounts[1], accounts[3], 10),
    Order(accounts[3], accounts[2], 2)};
  int numberOfOrders = sizeof(orders) / sizeof(orders[0]);
 
  // сортировка
  std::sort(orders, orders + numberOfOrders, orderSourceComparator);
  // вывод всех ордеров
  for (const Order *i = orders; i != orders + numberOfOrders; ++i) {
    std::cout << *i << std::endl;
  }
  
  
  // нижеприведенную строку нужно ввести, но мне снова лень
  std::string accountIdToSearch = "000";
  const Account *accountToSearch = search(accountIdToSearch, accounts, 
    accounts + numberOfAccounts);
    
  if (accountToSearch != 0) {      
    int totalOperations = 0;
    int totalAmountTaken = 0;
    for (const Order *i = orders; i != orders + numberOfOrders; ++i) {
      if (i->getSource() == *accountToSearch) {
        ++totalOperations;
        totalAmountTaken += i->getAmount();
      }
    }
    if (totalOperations != 0) {
      std::cout << "Total withdrowal from account \"" << 
        accountIdToSearch << "\": " << totalAmountTaken << "." <<
        std::endl;      
    } else {
      std::cout << "Nothing was taken from account \"" << 
        accountIdToSearch << "\"." << std::endl;
    }
  } else {
    std::cout << "Account \"" << accountIdToSearch << "\" not found." <<
      std::endl;
  }
 
  return 0;
}
0
zmei87
0 / 0 / 0
Регистрация: 27.10.2013
Сообщений: 10
29.10.2013, 23:08  [ТС] #6
Цитата Сообщение от lemegeton Посмотреть сообщение
У вас очень много косяков. Начать с того, где закрывается функция main.

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
114
115
116
117
118
119
120
121
122
123
124
125
#include <iostream>
#include <string>
#include <algorithm>
 
class Account {
 public:
  Account(const std::string &id) : id(id) {}
  const std::string &getId() const {
    return id;
  }
 private:
  std::string id;
};
 
std::ostream &operator<<(std::ostream &stream, const Account &a) {
  return stream << "Account{" <<
    "id=\"" << a.getId() << "\"}";
}
 
bool operator==(const Account &a, const Account &b) {
  return a.getId() == b.getId();
}
 
bool operator<(const Account &a, const Account &b) {
  return a.getId() < b.getId();
}
 
class Order {
 public:
  Order(const Account &source, const Account &destination, int amount)
    : source(source), destination(destination), amount(amount) {}
  const Account &getSource() const {
    return source;
  }
  const Account &getDestination() const {
    return destination;
  }
  int getAmount() const {
    return amount;
  }
 private:
  Account source;
  Account destination;
  int amount;
};
 
int orderSourceComparator(const Order &a, const Order &b) {
  return a.getSource() < b.getSource() ? 1 :
    a.getSource() == b.getSource() ? 0 : -1;
}
 
std::ostream &operator<<(std::ostream &stream, const Order &o) {
  return stream << "Order{" <<
    "source=" << o.getSource() << ", " <<
    "destination=" << o.getDestination() << "}";
}
 
/**
 * Ищет аккаунт с указанным id.
 * 
 * @param id id аккаунта для поиска
 * @param first указатель на первый аккаунт  
 * @param last указатель на  аккаунт после последнего  
 * @return 0, если аккаунт не найден или указатель на аккаунт
 */ 
const Account *search(const std::string id, const Account *first,
  const Account *last) {
  while (first != last) {
    if (first->getId() == id) {
      return first;
    }
    ++first;
  }
  return 0;
}
 
int main(int, char**) {
  // заготовка
  // это все надо вводить, но мне лень
  Account accounts[] = { Account("000"), Account("111"), Account("222"),
    Account("333")};
  int numberOfAccounts = sizeof(accounts) / sizeof(accounts[0]);
  Order orders[] = { Order(accounts[0], accounts[2], 7),
    Order(accounts[1], accounts[0], 5),
    Order(accounts[1], accounts[3], 10),
    Order(accounts[3], accounts[2], 2)};
  int numberOfOrders = sizeof(orders) / sizeof(orders[0]);
 
  // сортировка
  std::sort(orders, orders + numberOfOrders, orderSourceComparator);
  // вывод всех ордеров
  for (const Order *i = orders; i != orders + numberOfOrders; ++i) {
    std::cout << *i << std::endl;
  }
  
  
  // нижеприведенную строку нужно ввести, но мне снова лень
  std::string accountIdToSearch = "000";
  const Account *accountToSearch = search(accountIdToSearch, accounts, 
    accounts + numberOfAccounts);
    
  if (accountToSearch != 0) {      
    int totalOperations = 0;
    int totalAmountTaken = 0;
    for (const Order *i = orders; i != orders + numberOfOrders; ++i) {
      if (i->getSource() == *accountToSearch) {
        ++totalOperations;
        totalAmountTaken += i->getAmount();
      }
    }
    if (totalOperations != 0) {
      std::cout << "Total withdrowal from account \"" << 
        accountIdToSearch << "\": " << totalAmountTaken << "." <<
        std::endl;      
    } else {
      std::cout << "Nothing was taken from account \"" << 
        accountIdToSearch << "\"." << std::endl;
    }
  } else {
    std::cout << "Account \"" << accountIdToSearch << "\" not found." <<
      std::endl;
  }
 
  return 0;
}
извините, а что это за код =)?
0
lemegeton
2925 / 1354 / 135
Регистрация: 29.11.2010
Сообщений: 2,725
29.10.2013, 23:24 #7
В коде есть счет, ордер, упорядочивание ордеров, поиск аккаунта, поиск выплат по аккаунту.
0
zmei87
0 / 0 / 0
Регистрация: 27.10.2013
Сообщений: 10
29.10.2013, 23:26  [ТС] #8
Цитата Сообщение от lemegeton Посмотреть сообщение
В коде есть счет, ордер, упорядочивание ордеров, поиск аккаунта, поиск выплат по аккаунту.
но мне надо описать структуру ордер, а не аккаунт
0
lemegeton
2925 / 1354 / 135
Регистрация: 29.11.2010
Сообщений: 2,725
29.10.2013, 23:30 #9
Перечитайте код и мое предыдущее сообщение внимательней.
0
zmei87
0 / 0 / 0
Регистрация: 27.10.2013
Сообщений: 10
30.10.2013, 03:02  [ТС] #10
Цитата Сообщение от lemegeton Посмотреть сообщение
Перечитайте код и мое предыдущее сообщение внимательней.
т.е. оба кода выпоняют одну и ту же задачу?

Добавлено через 3 часа 25 минут
ап тему
0
Zig_Stas
8 / 8 / 1
Регистрация: 26.10.2013
Сообщений: 55
30.10.2013, 06:55 #11
Цитата Сообщение от zmei87 Посмотреть сообщение
т.е. оба кода выпоняют одну и ту же задачу?

Добавлено через 3 часа 25 минут
ап тему
Господя, ну переименуй ты Account в Order и все><
0
30.10.2013, 06:55
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
30.10.2013, 06:55
Привет! Вот еще темы с ответами:

Доработать программу - C++
Ниже рабочая программа, но надо сделать без использования циклов (кроме уже имеющегося) и функций (аля pow). Проблема в том что я не пойму...

Доработать программу - C++
Здравствуйте, преподавателю не нравится как выполнена задача,жалуется на формулу и требует её сократить (о чем в задаче не упоминается) при...

Доработать программу - C++
День добрый. У меня есть программа, которая удваивает каждый символ, из введенной строки. Как сделать, чтобы удвоенная пара символов...

Структуры))доработать программу - C++
Вот программа. Чуть не доделанная. Вот задание: Создать структуру, реализующую стек целых чисел типа LIFO. Данные структуры: массив...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru