马拦过河卒(双重循环实现)-洛谷-P1002
bigegpt 2024-09-22 00:49 6 浏览
P1002 [NOIP2002 普及组] 过河卒
一、题目描述
二、一些关键信息:
1、一个点的来源路径只能是上路径或者左路径。
2、换成字母描述:
一个点是A,A点的做路径来源是B,A点的上路径来源是C
那么A、B和C的坐标分别就是:
f(x,y)、f(x-1,y)、f(x,y-1)
3、可能性描述:
B点从起始点走过来的路径可能性是m,
C点从起始点走过来的路径可能性是n
那么到达A点的可能性只能是m+n
4、利用坐标表示可能性那么得到公式
5、特殊点的可能性:
三、代码编写
1、数据变量准备:
//数量的准备 说明/提示里有最大值的范围,超过最大值就可以
#define SL 30
//B点坐标 马的坐标
int xb = 0,yb = 0,xm = 0,ym = 0;
//棋盘
int qp[SL][SL] = {0};
//每个点对应步数的准备
int bs[SL][SL] = {0};
2、输入B点的坐标和马的坐标
//输入 B点 马的坐标
cin >> xb >> yb >> xm >> ym;
3、整体平移
//整体平移
xb+=2;yb+=2;xm+=2;ym+=2;
4、特殊点赋值
//特殊点 边界和马的坐标
//初始化 C++的二维数组的初始化方式有限,不能直接使用[][]的方式来初始化
for(int i =0;i<SL;i++){
for(int j=0;j<SL;j++){
bs[i][j] = 0;
qp[i][j] = 0;
}
}
//边界
for(int i=2;i<SL;i++){
bs[i][0] = 1;//横线
bs[0][i] = 1;//竖线
}
//马的控制点
qp[xm][ym] = 1;
qp[xm-2][ym-1] = 1;
qp[xm-1][ym-2] = 1;
qp[xm-2][ym+1] = 1;
qp[xm-1][ym+2] = 1;
qp[xm+2][ym+1] = 1;
qp[xm+2][ym-1] = 1;
qp[xm+1][ym-2] = 1;
qp[xm+1][ym+2] = 1;
5、递推计算
//递推计算
bs[1][2] = 1;
for(int i =2;i<=xb;i++){
for(int j=2;j<=yb;j++){
if(qp[i][j] == 0) {
bs[i][j] = bs[i-1][j] + bs[i][j-1];
}
}
}
6、输出打印查看
//打印查看
for(int i =0;i<SL;i++){
for(int j=0;j<SL;j++){
cout << bs[i][j] << " ";
}
cout << endl;
}
//输出
cout << bs[xb][yb] << endl;
最终结果
四、所有代码(通过测评)
#include <bits/stdc++.h>
using namespace std;
#define SL 30
long long xa = 0,ya = 0;
long long xm = 0,ym = 0;
long long qp[SL][SL] = {0};
long long f[SL][SL] = {0};
int main() {
//输入这四个数
cin >> xa >> ya >> xm >> ym;
xa+=2;
ya+=2;
xm+=2;
ym+=2;
for(int i=0;i<SL;i++){
for(int j=0;j<SL;j++){
qp[i][j] = 0;
f[i][j] = 0;
}
}
//特殊点
for(int i=2;i<SL;i++){
f[i][2] = 1;
f[2][i] = 1;
}
qp[xm][ym] = 1;
qp[xm-1][ym+2] = 1;
qp[xm-1][ym-2] = 1;
qp[xm-2][ym+1] = 1;
qp[xm-2][ym-1] = 1;
qp[xm+1][ym+2] = 1;
qp[xm+1][ym-2] = 1;
qp[xm+2][ym+1] = 1;
qp[xm+2][ym-1] = 1;
f[1][2] = 1;
for(int i=2;i<=xa;i++){
for(int j=2;j<=ya;j++){
if(qp[i][j]==0){
f[i][j] = f[i-1][j] + f[i][j-1];
}else{
f[i][j] = 0;
}
}
}
//输出
cout << f[xa][ya] << endl;
return 0;
}
- 上一篇:二维数组
- 下一篇:?鹏哥C语言第一课? 第51.1讲 二维数组的概念#二维数组
相关推荐
- Dify「模板转换」节点终极指南:动态文本生成进阶技巧(附代码)Jinja2引擎解析
-
这篇文章是关于Dify「模板转换」节点的终极指南,解析了基于Jinja2模板引擎的动态文本生成技巧,涵盖多源文本整合、知识检索结构化、动态API构建及个性化内容生成等六大应用场景,助力开发者高效利用模...
- 我用C#造了个AI程序员:自动调试+重构代码实战
-
在软件开发的世界里,调试和重构代码往往占据了程序员大量的时间。我一直梦想着能有一个智能助手,帮我处理这些繁琐的工作。于是,我决定用C#打造一个AI程序员,让它具备自动调试和重构代码的能力。系统架构设计...
- 公文自动排版vba代码(公文自动排版vba代码)
-
Sub公文自动排版()'设置页面参数(单位:厘米)WithActiveDocument.PageSetup.TopMargin=CentimetersToPoints(3.7)...
- Anthropic最强代码神器:Claude Code系统提示词
-
最近,在融合Opus-4之后,ClaudeCode的整体能力直线飙升.甚至一度把曾经的最强开发工具——Cursor打的抬不起头来。无论是代码生成的准确度,还是智能补全的丝滑体验,都让人印象深...
- 使用 Ruff 进行 Python 代码格式化与静态检查
-
随着Python项目的规模增大,保持一致的代码风格和高质量的代码变得尤为重要。Ruff是一个现代、高性能、支持lint和格式化的Python工具,能帮助你快速发现并修复常见代码问题。本文...
- 基础语法篇:格式化输出 含完整示例代码
-
所谓格式化输出就是按照一定格式来输出对应的内容,在Python的语法中格式化输出包含两种:格式化符号、格式化字符串一、格式化符号常用的格式化符号包括%s(将内容转换为字符串,放入占位位置)、%d(将内...
- 代码整洁如诗!Keil 插件上线,一键格式化代码,告别风格混乱!
-
引言:代码格式不统一?你的团队还在为“括号位置”吵架吗?嵌入式开发者们,你是否经历过这些抓狂瞬间?代码风格“百花齐放”:同事的代码缩进用空格,你的用Tab,合并时冲突频发!手动调整耗时费力:为了通过C...
- [信捷PLC] 信捷PLC之C函数编程(一)
-
前言写PLC程序,越来越觉得结构化文本编程语言(ST)给PC编程带来的便利,在处理一些数据上,可以写的更加灵活。所以,在项目PLC选型上,我都会优先选择支持结构化文本的PLC。国内有些厂商推出了一些较...
- C语言-HelloWorld解析(c语言的helloworld怎么写)
-
使用VisualStudio2017开发工具新创建一个项目,编写第一个C语言程序。#include<stdio.h>voidmain(){printf("HelloW...
- VSCode 配置 C++ 开发环境!教程详解
-
第一步、安装VSCode应用程序打开VSCode官网,下载对应安装包并默认安装(这里指明:安装路径可以修改)第二步、安装相关插件此时的VSCode仅仅是一个英文文本编辑器,还称不上开发工具,所以需要...
- C语言进阶教程:C语言与汇编语言交互
-
C语言和汇编语言的交互是底层编程和性能优化中的一个重要方面。理解它们如何协同工作,可以帮助开发者更好地控制硬件、优化关键代码段以及理解编译器的行为。为什么需要在C语言中嵌入汇编?尽管C语言已经提供了相...
- C语言如何处理平台相关代码(c语言的开发平台)
-
在进行跨平台C编程时,不可避免地会遇到需要针对不同操作系统或硬件架构编写特定代码的情况。C语言通过预处理器指令,特别是条件编译指令,为我们提供了处理平台相关代码的有效机制。最常用的就是利用预定义的宏(...
- C语言:hello world(c语言helloworld代码)
-
环境:a.初学者建议用“啊哈C”,这款软件简单易装;b.devc.visualstdiod.Vc6.0第一行代码:#include<stdio.h>#<stdio.h&g...
- C语言之编译器集合(编写c语言编译器)
-
C语言有多种不同的编译器,以下是常见的编译工具及其特点:一、主流C语言编译器1.GCC(GNUCompilerCollection)特点:开源、跨平台,支持多种语言(C、C++、Fortran...
- 适合零基础初学者学习C语言第一课教程,揭开C语言的神秘面纱
-
一、C语言简介我刚接触编程,首先想要学习的就是C语言,这次我就把我的感悟用我自己理解的文字表述出来,这样对刚学C语言的人来说,才是比较友好的。因为我们都没有C语言的基础,不懂啥是编程,啥事代码。我们...
- 一周热门
- 最近发表
- 标签列表
-
- mybatiscollection (79)
- mqtt服务器 (88)
- keyerror (78)
- c#map (65)
- xftp6 (83)
- bt搜索 (75)
- c#var (76)
- xcode-select (66)
- mysql授权 (74)
- 下载测试 (70)
- linuxlink (65)
- pythonwget (67)
- androidinclude (65)
- libcrypto.so (74)
- linux安装minio (74)
- ubuntuunzip (67)
- vscode使用技巧 (83)
- secure-file-priv (67)
- vue阻止冒泡 (67)
- jquery跨域 (68)
- php写入文件 (73)
- kafkatools (66)
- mysql导出数据库 (66)
- jquery鼠标移入移出 (71)
- 取小数点后两位的函数 (73)