Форум программистов, компьютерный форум, киберфорум
C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.68/25: Рейтинг темы: голосов - 25, средняя оценка - 4.68
0 / 0 / 0
Регистрация: 28.08.2024
Сообщений: 1

Посчитать количество способов, которым ладья может добраться до нижней правой клетки доски

28.08.2024, 06:15. Показов 5886. Ответов 23
Метки с++ (Все метки)

Студворк — интернет-сервис помощи студентам
В верхней левой клетке доски сидит ладья. Она умеет ходить на любое количество клеток вправо и вниз. Необходимо посчитать количество способов, которым эта ладья может добраться до нижней правой клетки доски.

Входные данные:

Входные данные содержат два целых числа n, m (1≤n,m≤100) - количество строк и столбцов в таблице. Таблица может быть прямоугольная.

Выходные данные:
Выведите единственное число k = количество способов добраться до нижней правой клетки.
Решалось через префиксные суммы, но ошибку не найду. Возможно, есть другие способы.
Подскажите, пожалуйста, что не так?

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
#include <iostream>
#include <vector>
 
 
int count_rook_ways(int n, int m) {
    // Создаем таблицы для подсчета количества путей и префиксных сумм
    std::vector<std::vector<int>> dp(n, std::vector<int>(m, 0));
    std::vector<std::vector<int>> pr(n, std::vector<int>(m, 0));  // Префиксные суммы по строкам
    std::vector<std::vector<int>> pr2(n, std::vector<int>(m, 0)); // Префиксные суммы по столбцам
 
    // Начальная точка
    dp[0][0] = 1;
    pr[0][0] = 1;
    pr2[0][0] = 1;
 
    for (int i = 0; i < n; ++i) {
        for (int j = 0; j < m; ++j) {
            if (i > 0) {
                dp[i][j] += pr[i-1][j];  // Пути из верхней клетки
            }
            if (j > 0) {
                dp[i][j] += pr2[i][j-1];  // Пути из левой клетки
            }
 
            // Обновляем префиксные суммы
            pr[i][j] = dp[i][j] + (i > 0 ? pr[i-1][j] : 0);
            pr2[i][j] = dp[i][j] + (j > 0 ? pr2[i][j-1] : 0);
        }
    }
 
    return dp[n-1][m-1];
}
 
int main() {
    int n, m;
    std::cin >> n >> m;
 
    // Вывод результата
    std::cout << count_rook_ways(n, m) << std::endl;
 
    return 0;
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.08.2024, 06:15
Ответы с готовыми решениями:

Выяснить можно ли составить такие пары чисел, чтобы они обозначали поля шахматной доски, по которым может ходить ладья
Нет времени сильно углубляться. Буду премного благодарен,если поясните с примерами и с подробным пояснением Сами задача ниже Даны...

Клетчатая доска - Определить количество способов добраться до последней клетки N-M
Привет. Задача такая: дана клетчатая доска NxM (-1000 &lt;= N,M &lt;= 1000), мы находимся в самой первой клетке 1-1. Нужно определить количество...

Определить, за какое наименьшее количество ходов конь сможет добраться с клетки (x1,y1) доски M×N на клетку (x2,y2)
задача на коня олимпидная с++ решите на с++ пожалуйста. (p,q) - конь Ограничение времени 1 секунда Ограничение памяти 64Mb ...

23
Вездепух
Эксперт CЭксперт С++
 Аватар для TheCalligrapher
13205 / 6840 / 1822
Регистрация: 18.10.2014
Сообщений: 17,298
28.08.2024, 22:17
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от TheCalligrapher Посмотреть сообщение
я получаю такое же значение и по своей формуле
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
#include <cassert>
#include <algorithm>
#include <iostream>
#include <boost/multiprecision/cpp_int.hpp>
 
using boost::multiprecision::cpp_int;
 
cpp_int Cnk(unsigned n, unsigned k)
{
  assert(n >= k);
 
  if (n == 0)
    return 1;
 
  cpp_int num = 1;
  for (unsigned f = n; f > k; --f)
    num *= f;
    
  cpp_int den = 1;
  for (unsigned f = n - k; f > 1; --f)
    den *= f;
    
  return num / den;
} 
 
cpp_int count_rook_ways(unsigned n, unsigned m)
{
  assert(n > 0 && m > 0);
 
  if (n > m)
    std::swap(n, m);
 
  if (m == 1)
    return 1;
 
  cpp_int res = 0;
 
  if (n == 1)
    for (unsigned j = 1; j < m; ++j)
      res += Cnk(m - 2, j - 1);
  else
    for (unsigned i = 1; i < n; ++i)
      for (unsigned j = 1; j < m; ++j)
        res += Cnk(n - 2, i - 1) * Cnk(m - 2, j - 1) * Cnk(i + j, j);
 
  return res;
}
 
int main() 
{
  unsigned n = 0, m = 0;
  std::cin >> n >> m;
  std::cout << count_rook_ways(n, m) << std::endl;
}
1
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6266 / 2990 / 1051
Регистрация: 01.06.2021
Сообщений: 11,071
28.08.2024, 22:21
TheCalligrapher, ваша формула и код ТС выдают одно и то же
0
 Аватар для Mr_den
11 / 9 / 2
Регистрация: 06.09.2022
Сообщений: 408
30.08.2024, 15:38
за 1 ход: только 1 способ
иЛИ ТАКИЕ СПОСОБЫ ТОЖЕ СЧИТАТЬ ?
0
 Аватар для SmallEvil
4086 / 2975 / 813
Регистрация: 29.06.2020
Сообщений: 11,000
31.08.2024, 08:26
Цитата Сообщение от Mr_den Посмотреть сообщение
иЛИ ТАКИЕ СПОСОБЫ ТОЖЕ СЧИТАТЬ ?
Фигура не может ходить вверх, я для кого объяснял ?
Ах да, это было лично для Royal_X, больше никого это не касается, понятно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
31.08.2024, 08:26
Помогаю со студенческими работами здесь

Посчитать количество различных комбинаций прыжков, которые помогут добраться из нулевой клетки в клетку n
Задание: Кузнечик прыгает по клеточкам тетрадного листа, за один прыжок он перепрыгивает от L до R клеток. Посчитать количество различных...

Определить количество способов которыми заяц может добраться до вершины лестницы
Задали задание в школе. Я, конечно, понимаю, что надо использовать динамическое программирование, но до меня очень долго доходит решение. ...

Найти количество способов, которыми фишка может дойти до последней клетки
Фишка может двигаться по полю длины N только вперед. Длина хода фишки не более K. Найти количество способов, которыми фишка может дойти до...

Определить количество валунов к которым четвёртый кот может добраться строго быстрее других котов
Кот Бенедикт любит наблюдать из окна за происходящим в парке. На одном из газонов парка устроили инсталляцию из камней. Мелкие камни...

Получить количество возможных уникальных путей, по которым робот может добраться до нижнего правого угла
На сетке m x n стоит робот. Робот изначально расположен в верхнем левом углу (т. е. grid). Робот пытается переместиться в нижний правый...


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

Или воспользуйтесь поиском по форуму:
24
Ответ Создать тему
Новые блоги и статьи
[golang] Алгоритм «Хак Госпера»
alhaos 17.05.2026
Алгоритм «Хак Госпера» Хак Госпера (Gosper's Hack) — алгоритм нахождения следующего по величине числа с тем же количеством установленных бит. Придуман Биллом Госпером в 1970-х, опубликован в. . .
Рисование бинарного древа до 6-го колена на js, svg.
russiannick 17.05.2026
<svg width="335" height="240" viewBox="0 0 335 240" fill="#e5e1bb"> <style> <!]> </ style> <g id="bush"> </ g> </ svg> function fn(){ let rost;/ / высота древа let xx=165,yy=210,w=256;
FSharp: interface of module
DevAlt 16.05.2026
Интерфейс модуля F# позволяет управлять доступностью членов, содержащихся в реализации модуля. По-умолчанию все члены модуля доступны: module Foo let x = 10 let boo () = printfn "boo" . . .
Хитросплетение родственных связей пантеона греческих богов.
russiannick 14.05.2026
Однооконник, позволяющий узреть и изучить отдельных героев древней Греции. <!DOCTYPE html> <html lang="ru"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible". . .
[golang] Угол между стрелками часов
alhaos 12.05.2026
По заданным значениям часа и минуты необходимо определить значение меньшего угла между стрелками аналогового циферблата часов. import "math" func angleClock(hour int, minutes int) float64 { . . .
Debian 13: Установка Lazarus QT5
ВитГо 09.05.2026
Эта инструкция моя компиляция инструкций volvo https:/ / www. cyberforum. ru/ blogs/ 203668/ 10753. html и его же старой инструкции по установке Lazarus с gtk2. . .
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер. Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
Асинхронный приём данных из COM-порта
Argus19 01.05.2026
Асинхронный приём данных из COM-порта Купил на aliexpress термопринтер QR701. Он оказался странным. Поключил к Arduino Nano. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru