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

Программа расчета выгодности шантажистов - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Что означает запись? http://www.cyberforum.ru/cpp-beginners/thread1348511.html
for (; j < k; j++) - Что означает эта строчка? Интересует именно символ ";" сразу после скобки
C++ Собрать double не по формуле Есть два знакового числа типа int64_t: порядок и мантисса, причём, точка перенесена за младший разряд мантиссы, оба числа знаковые без сдвигов, все биты явные. Требуется собрать число double IEEE 754, используя только битовые и целочисленные операции, чтоб это было эквивалентно m*2^{p-52}, где m - мантисса, p - порядок. http://www.cyberforum.ru/cpp-beginners/thread1348509.html
C++ Задания к олимпиаде
1.Имеется 100 рублей. Сколько быков, коров и телят можно купить на все эти деньги, если плата за быка – 10 рублей, за корову – 5 рублей, за теленка – полтинник (0,5 рубля) и надо купить 100 голов скота? #== 2.Даны два слова. Напечатать только те буквы слов, которые есть только в одном из них (в том числе повторяющиеся). Например, если заданные слова процессор и информация, то...
C++ Определить фамилии мужчины и женщины, имеющих самую маленькую зарплату
Помогите решить задачу. Известны данные о 20 сотрудниках фирмы (фамилия, зарплата и пол). Определить фамилии мужчины и женщины, имеющих самую маленькую зарплату (считать, что такие есть и они единственные в своей группе сотрудников).
C++ Перенести первые k строк в конец матрицы, соблюдая порядок их следования (Паскаль -> С++) http://www.cyberforum.ru/cpp-beginners/thread1348482.html
Условие Дан двумерный массив из двадцати строк и трех столбцов. Перенести первые k строк в конец массива, соблюдая порядок их следования. uses crt; const n=20; var x,y:array of integer; i,j,k,err,temp:integer; procedure perenos; begin repeat
Pascal Нахождение суммы элементов матрицы, находящихся выше и ниже главной диагонали Дана действительная квадратная матрица порядка n Рассмотрим элементы которые начинаются с отрицательного элемента . Найти сумму тех которые расположены соответственно выше и ниже главной диагонали наброска нет набросок в коледже извините предоставить не могу помогите пожалуйста подробнее

Показать сообщение отдельно
tnk500
113 / 117 / 25
Регистрация: 25.08.2012
Сообщений: 1,211
Завершенные тесты: 3
08.01.2015, 12:03     Программа расчета выгодности шантажистов
Пишу программу, которая рассчитывает выгодность двух шантажистов. Смысл вот в чем. Вам дается кучка людей и предлагается выбрать среди них двух шантажистов. Каждый может обмануть определенное количество людей, в том числе и своего конкурента. Собственно, это и должна определить программа - кто выгодней, путем сравнения людей.
Программа относительно проста, но я столкнулся с какой-то неуловимой ошибкой. Ругается на срабатывание точки останова (программа запускается и работает до момента, когда вы вводите номера шантажистов) в файле free.c в строчке 50, которая про retval = HeapFree(_crtheap, 0, pBlock);.
Целую ночь убил на поиск ошибки, изменял программу и так и сяк, везде были непонятные ошибки на различные файлы. Думаю, связано с памятью.

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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
#include <cstdlib>
#include <iostream>
#include <ctime>
#include <cmath>
 
class Man
{
    int numberOfMan;                            //номер шантажиста среди людей
    int howManyPeople;                          //сколько человек данный чел может шантажировать
    int *numbersOfMailed;                       //массив с номерами этих людей
    static int allPeople;                       //количество всех людей
public:
    Man( int number )
        : howManyPeople(number)
    {
        if(!allPeople)
        {
            std::cout << "Enter, how many people there are:\n";
            std::cin >> allPeople;
        }
        std::cout << "Enter the number of the blackmailer: ";
        std::cin >> numberOfMan;
        numbersOfMailed = new int(howManyPeople);
    }
    ~Man()
    {
        delete [] numbersOfMailed;
    }
    void initTheArray()
    {
        if(!howManyPeople)
        {
            std::cerr << "Number of blackmailed people is not stated!\n";
            return;
        }
        for(int i = 0; i < howManyPeople; ++i)
            numbersOfMailed[i] = 0 + rand() % allPeople;
    }
 
    int getQuanOfMailed()
    {
        return howManyPeople;
    }
 
    void getNumbersOfMailed()
    {
        for(int i = 0; i < howManyPeople; ++i)
        {
            std::cout << numbersOfMailed[i] << " ";
        }
        std::cout << "\n";
    }
 
    int getAllPeople() const
    {
        return allPeople;
    }
 
    int whoCanMore( Man& second )                           
    {                                                               
        bool firstToSec = false, secToFirst = false;
        for(int i = 0; i < this->howManyPeople; ++i)
        {
            if(this->numbersOfMailed[i] == second.numberOfMan)
                firstToSec = true;
        }
        for(int i = 0; i < second.howManyPeople; ++i)
        {
            if(second.numbersOfMailed[i] = this->numberOfMan)
                secToFirst = true;
        }
 
        if(this->howManyPeople > second.howManyPeople && firstToSec)            //рассчитывает, кто выгодней. Вернет 1, если первый, 2 - второй,
            return 6;                                                           //ноль - оба могут шантажировать одинаковое кол-во людей
        else if(this->howManyPeople > second.howManyPeople)                     //3 - если первый может шантажировать второго
            return 1;                                                           //4 - если наоборот
        else if(this->howManyPeople < second.howManyPeople && secToFirst)       //5 - если оба
            return 7;                                                           //6 - если первый может больше обмануть, но второй 
        else if(this->howManyPeople < second.howManyPeople)                     //может обмануть первого
            return 2;                                                           //7 - если наоборот
        else
        {
            if(firstToSec && secToFirst)
                return 5;
            else if(firstToSec)
                return 3;
            else if(secToFirst)
                return 4;
            else 
                return 0;
        }
    }
 
    int difference( Man& second )                                       //если у шантажистов не одинак. кол-во "подчиненных людей,
    {                                                                   //высчитает разницу между ними, в против. случае возвр. 0
        if(this->howManyPeople != second.howManyPeople)
            return abs( this->howManyPeople - second.howManyPeople);
        else
            return 0;
    }
};
 
int Man::allPeople;
 
int main()
{
    srand(time(0));
    int menOfFirst, menOfSecond;
    std::cout << "Enter the quantity of men who can be blackmailed by the first and the second man:\n";
    std::cin >> menOfFirst >> menOfSecond;
 
    Man first(menOfFirst), second(menOfSecond);
    first.initTheArray (); second.initTheArray ();
    int allPeople = first.getAllPeople();
    int *people = new int(allPeople);
    for(int i = 0; i < allPeople; ++i)
    {
        people[i] = i + 1;
    }
 
    switch(first.whoCanMore(second))
    {
    case 1:
        {
        std::cout << "The first blackmailer can blackmail more people. Hire him.\n"
            << "The difference between them is\n";
        break;
        }
    case 2:
        std::cout << "The second blackmailer can blackmail more people. Hire him.\n"
            << "The difference between them is " << first.difference(second) << "\n";
        break;
    case 3:
        std::cout << "They can blackmail the same quantity of people, but the first can blackmail the second.\n"
            << "It would be better if you hire him.\n";
        break;
    case 4:
        std::cout << "They can blackmail the same quantity of people, but the second can blackmail the first.\n"
            << "It would be better if you hire him.\n";
        break;
    case 5:
        std::cout << "Don't hire both: they can blackmail the same quantity of people, but also\n"
            << "blackmail each other. Find the new blackmailer.\n";
        break;
    case 6:
        std::cout << "The first blackmailer can delude more people, but the second can blackmail him, so be careful with choice.\n"
            << "The difference between them is\n";
        first.getNumbersOfMailed();
        second.getNumbersOfMailed ();
        break;
    case 7:
        std::cout << "The second blackmailer can delude more people, but the first can blackmail him, so be careful with choice.\n"
            << "The difference between them is " << first.difference (second);
        break;
    case 0:
        std::cout << "Both blackmailers can delude the same quantity of people, hire whoever you want.\n";
        break;
    default:
        std::cout << "Cannot figure out!\n";
        break;
    }
    delete [] people;
    system("pause");
    return 0;
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 15:18. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru