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

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

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

Результаты бросков спортсменов в матрице. Найти победителя - C++

20.04.2014, 14:42. Просмотров 362. Ответов 2
Метки нет (Все метки)

В метании молота состязается n спортcменов. Каждый из них сделал m бросков. Побеждает спортсмен, у которого максимален наилучший бросок. Если таких несколько, то из них побеждает тот, у которого наилучшая сумма результатов по всем попыткам. Если и таких несколько, победителем считается спортсмен с минимальным номером. Определите номер победителя соревнований.
Формат входных данных

Программа получает на вход два числа n и m, являющиеся числом строк и столбцов в массиве. Далее во входном потоке идет n строк по m чисел, являющихся элементами массива.

Формат выходных данных

Программа должна вывести одно число - номер победителя соревнований. Не забудьте, что строки (спортсмены) нумеруются с 0.

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
#include <iostream>
using namespace std;
int main() {
    int x, y; int max; int index = 0; int maxCost, cost; int ind = 0; int counter = 0; int indexx = 0;
    int mas[101][101];
    cin >> x >> y;
    for (int i = 0; i < x; i++)
    for (int j = 0; j < y; j++)
        cin >> mas[i][j];
    max = mas[0][0];
    for (int i = 0; i < x; i++){
        for (int j = 0; j < y; j++) {
            if (mas[i][j]>max) { max = mas[i][j]; index = i; }
        }
    }
    for (int i = 0; i < x; i++){
        for (int j = 0; j < y; j++){
            if (mas[i][j] == max) {
                indexx = i;
                counter++;
            }
        }
        maxCost = mas[0][0];
            for (int j = 0; j < y; j++) {
                int cost = 0;
                cost += mas[indexx][j];
                if (cost>maxCost){
                    maxCost = cost; ind = indexx;
                    cost = 0;
                }
            }
    }
    cout << indexx;
        return 0;
}
Код работает лишь в 7 случаях из 12. Скажите пожалуйста где ошибка, или если Вам вообще не понятен мой код, то Я с радостью приму Ваш вариант. Заранее спасибо!)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.04.2014, 14:42
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Результаты бросков спортсменов в матрице. Найти победителя (C++):

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

Определить результаты спортсменов, занявших первое и второе места - C++
3. В двух массивах записаны результаты 20 игр двух футбольных команд (если игра окончилась выигрышем данной команды, то записано число 2,...

Структуры: ввести спортсменов, результаты и определить занятые ими места - C++
Определить тип данных запись, имеющий поля фамилия, страна и результаты 6 выстрелов. Определить массив из 10 записей. В программе ввести в...

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

Найти последовательность номеров удаляемых спортсменов - C++
Добрый день! Подскажите пожалуйста, правильно ли я написал программу, а то преподаватель не согласен с ним. Вот условие задачи: По...

Програма должна имитировать n бросков игральной кости - C++
помогите програма должна имитировать n бросков игральной кости #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; #include...

2
nmcf
5324 / 4644 / 1553
Регистрация: 14.04.2014
Сообщений: 18,479
20.04.2014, 15:37 #2
Сначала найди максимумы по каждому спортсмену и сумму результатов по каждому спортсмену. Сохрани в массивы.
Затем найди максимум из максимумов (allmax). И наконец просматривая массивов из максимумов, выбери тех у кого бросок = allmax и сумма результатов максимальна. При строгом условии (>) ты самого первого и выберешь.
0
kasadi
0 / 0 / 0
Регистрация: 13.01.2014
Сообщений: 65
20.04.2014, 18:29  [ТС] #3
nmcf, если так судить то если из двух спортсменов у одного будут сумма результатов будет максимальной, а у другого будет макс. из макс., то результаты не сойдутся.
Я в своем коде пытался это объядинить, но где то есть промашка.
В общем не смог, кто что еще подскажет? =(
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
20.04.2014, 18:29
Привет! Вот еще темы с ответами:

В программе моделирующей бросок моенты, моделируется только 100 бросков Орла - C++
Написал программа для моделирования броска монеты, но почему - то при всегда выходит, что выпало 100 раз Орел. Подскажите, в чем дело ? ...

В матрице К размером m*n найти в каждом столбце произведение отрицательных элементов и количество нулевых элементов в матрице - C++
В матрице К размером m*n найти в каждом столбце произведение отрицательных элементов и количество нулевых элементов в матрице. Ребят,...

Найти и вывести полученные результаты - C++
Дана последовательность, состоящая из N чисел. Найти и вывести полученные результаты : 1. количество и сумму элементов, кратных 11; 2....

Известны результаты операций с числом. Найти его - C++
Из трехзначного числа х вычли его последнюю цифру. Когда резуль- тат разделили на 10, а к частному слева приписали последнюю цифру чис- ...


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

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

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