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

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

28.08.2024, 06:15. Показов 5958. Ответов 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
13210 / 6843 / 1824
Регистрация: 18.10.2014
Сообщений: 17,306
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
6296 / 3018 / 1053
Регистрация: 01.06.2021
Сообщений: 11,455
28.08.2024, 22:21
TheCalligrapher, ваша формула и код ТС выдают одно и то же
0
 Аватар для Mr_den
12 / 10 / 2
Регистрация: 06.09.2022
Сообщений: 417
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
Ответ Создать тему
Новые блоги и статьи
интеграция AnyLogic с самописным REST API и переход на Odoo
anaschu 03.07.2026
Успешная интеграция AnyLogic с самописным REST API и переход на промышленную Odoo WMS Сегодня проделал огромный путь от простой симуляции физических процессов до построения полноценной. . .
Поиск всех путей на ориентированном графе. Linux
dcc0 02.07.2026
Переработка старого кода из моей статьи. Через несколько переработок от PHP кода к C89 (надеюсь, 89). Но довольно запутанно получилось. Код для Linux. Но если убрать time и то, что с ним. . .
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы Всем привет! Хочу поделиться свежим (и довольно. . .
Где деньги лежат
kumehtar 02.07.2026
Это - японская подводная лодка I-52 (тип C2, кодовое имя Momi) вышла из Японии в марте 1944 года с миссией в оккупированную немцами Францию (Лорьян). Это была одна из «Янаги»-миссий по обмену. . .
Krabik для WoW 3.3.5a, многоязычный
AmbA 02.07.2026
Допилил бота, думаю что окончательно. Изменения: - добавлена многоязычность - добавлено снятие скриншотов - добавлено поддержание бафов хождения по воде (для жреца, дк и шамана) - и так, по. . .
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу))) Критические ошибки, мешающие компиляции и. . .
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата) Этот документ предназначен для того, чтобы новый чат Claude мог продолжить работу без необходимости заново разбираться в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru