9.1 NOIP普及组试题精解(2)
9-4 soldier.c
#include <stdio.h>
#define MAXN 21
};
int n, m, x, y; //n,m为B点的行列坐标位置,x,y为马的坐标位置
] = { -, -, , , , , -, - };
] = { , , , , -, -, -, - };
void horse() //初始化马和其控制点坐标位置
{
int i;
chessboard[x][y] = -; //标记马的位置
; i < ; i++) //标记马下一步的位置
{
&& x + dx[x] <= n) && (y + dy[i] >= )
&& (y + dy[i]) <= m)
chessboard[x + dx[i]][y + dy[i]] = -;
}
}
void search() //逐步搜寻出路
{
int i, j;
; i <= n; i++) //扫描第0列的各行
{
] != -) //若没有障碍
chessboard[i][] = ; //设置该位置可走路径数为1
else
break;
}
; i <= m; i++) //扫描第0行的每列
{
][i] != -) //若不是马的控制点
chessboard[][i] = ; //设置该位置可走路径数为1
else
break;
}
; i <= n; i++) //扫描各行各列
{
; j <= m; j++)
{
) //若该位置不是马的控制点
{
][j] != -) && (chessboard[i][j - ] != -)) //上面和左边也不是马的控制点
chessboard[i][j] = chessboard[i - ][j] + chessboard[i][j - ]; //将上面和左边的路径进行累加
][j] == -) && (chessboard[i][j - ] != -)) //若上面有马控制点,而左边无马控制点
chessboard[i][j] = chessboard[i][j - ]; //保存左边路径到到当前位置
][j] != -) && (chessboard[i][j - ] == -)) //若上面无马控制点,而左边有马控制点
chessboard[i][j] = chessboard[i - ][j]; //保存上面路径到当前位置
][j] == -) && (chessboard[i][j - ] == -)) //若上面和左边都有马的控制点
chessboard[i][j] = ; //当前位置无通路
}
}
}
}
int main()
{
int i, j;
FILE *fp1, *fp2;
if ((fp1 = fopen("soldier.in", "r")) == NULL)
{
printf("不能打开文件!\n");
exit();
}
fscanf(fp1,"%d%d%d%d", &n, &m, &x, &y);
fclose(fp1);
horse(); //初始化马及其下一步的位置
search();
if ((fp2 = fopen("soldier.out", "w")) == NULL)
{
printf("不能打开文件!\n");
exit();
}
printf("%d\n", chessboard[n][m]);
fprintf(fp2,"%d\n",chessboard[n][m]);
fclose(fp2);
getch();
;
}
9-5 isbn.c
#include <stdio.h>
int main()
{
] = { "0123456789X" };
];
int i, j, sum;
FILE *fp1, *fp2;
if ((fp1 = fopen("isbn.in", "r")) == NULL)
{
printf("不能打开文件!\n");
exit();
}
fgets(str, , fp1); //从文件中读取数据
fclose(fp1); //关闭文件
sum = ;
j = ;
; i < ; i++) //计算总和
{
&& i != )
sum += (str[i] - ') * j++;
}
sum %= ; //求模
if ((fp2 = fopen("isbn.out", "w")) == NULL)
{
printf("不能打开文件!\n");
exit();
}
] == table[sum]) //校验码正确
{
fputs("Right", fp2); //输出到文件
printf("Right\n");
}
else //校验码错误
{
str[] = table[sum]; //保存正确校验码
fputs(str, fp2); //输出正确的ISBN到文件
printf("%s\n", str);
}
fclose(fp2); //关闭文件
getch();
;
}
9.1 NOIP普及组试题精解(2)的更多相关文章
- 9.1 NOIP普及组试题精解(3)
9-6 seat.c #include <stdio.h> #define MAXN 1001 void swap(int *a, int *b) //交换数据 { int t; t = ...
- 9.1 NOIP普及组试题精解(1)
9-1 series1.c #include <stdio.h> int main() { float s=0.0,k; int n; printf("输入数字k(1~15):& ...
- 9.2 NOIP提高组试题精解(2)
9-18 fruit.c #include <stdio.h> #define MAXN 10000 int Queue1[MAXN], Queue2[MAXN]; void Insert ...
- 9.2 NOIP提高组试题精解(1)
9-16 poise.c #include <stdio.h> #define MAXN 1001 int main() { ], flag[MAXN] = { }; //保存6种砝码的数 ...
- 2016.10.6初中部上午NOIP普及组比赛总结
2016.10.6初中部上午NOIP普及组比赛总结 中了病毒--病毒--病毒-- 进度: 比赛:AC+0+0+20=120 改题:AC+0+AC+20=220 Stairs 好--简--单!递推就过了 ...
- 2016.8.15上午纪中初中部NOIP普及组比赛
2016.8.15上午纪中初中部NOIP普及组比赛 链接:https://jzoj.net/junior/#contest/home/1333 这次比赛不怎么好,因为这套题目我并不是很擅长. 可同学们 ...
- 2016.9.15初中部上午NOIP普及组比赛总结
2016.9.15初中部上午NOIP普及组比赛总结 2016.09.15[初中部 NOIP普及组 ]模拟赛 又翻车了!表示时超和空超很可恨! 进度 比赛:AC+0+0+20=120 改题:AC+80+ ...
- 2016.9.10初中部上午NOIP普及组比赛总结
2016.9.10初中部上午NOIP普及组比赛总结 链接:https://jzoj.net/junior/#contest/home/1340 好不爽!翻车了!不过排名差不多在中间偏上一点, 还好不是 ...
- 2016.9.3初中部上午NOIP普及组比赛总结
2016.9.3初中部上午NOIP普及组比赛总结 链接:https://jzoj.net/junior/#contest/home/1339 这次真爽,拿了个第四!(我还被班主任叫过去1小时呢!) 进 ...
随机推荐
- Android 项目开发实战:聚合数据短信验证码
聚合数据集成短信验证码官网: https://www.juhe.cn/docs/api/id/54 我根据文档集成了一个例子 效果: 源码下载:http://download.csdn.net/det ...
- Linux安装httpd2.4.10
1. cd /mnt tar zxvf httpd-2.4.10.tar.gz ./configure --prefix=/mnt/apache2 --enable-dav --enable-modu ...
- Chrome 插件 CrxMouse 去除后门优化版
说明 CrxMouse 是一款挺不错的 Chrome 插件.仅仅是据说这个插件会在后台偷偷的上传用户的浏览数据,无论上传的内容是不是涉及隐私数据,总让人认为不放心,可是因为插件本身功能还是挺好用的,所 ...
- python中给程序加锁之fcntl模块的使用
python 中给文件加锁——fcntl模块import fcntl 打开一个文件##当前目录下test文件要先存在,如果不存在会报错.或者以写的方式打开f = open('./test')对该文件加 ...
- RAM和ROM和Flash ROM的区别
转;http://openedv.com/thread-81182-1-1.html http://www.sohu.com/a/112676146 ...
- Intellj IDEA光标替insert状态,back键无法删除内容
Intellj IDEA光标为insert状态,无法删除内容导入项目后,发现打开java文件的光标是win系统下按了insert键后的那种宽的光标,并且还无法删除内容,且按删除(delete)键也只见 ...
- HTTP POST请求数据提交格式(转)
FROM: http://bbs.125.la/thread-13743350-1-1.html HTTP/1.1 协议规定的 HTTP 请求方法有 OPTIONS.GET.HEAD.POST.PUT ...
- hdu2473 Junk-Mail Filter 并查集+删除节点+路径压缩
Description Recognizing junk mails is a tough task. The method used here consists of two steps: 1) ...
- 初识python轻量web框架flask
1.使用pip安装Python包 大多数Python包都使用pip实用工具安装,使用pyvenv创建的虚拟环境会自动安装pip. 1.使用pip安装Flask(其它Python包同理) pip ins ...
- 【SSH进阶之路】Hibernate映射——一对一单向关联映射(五)
[SSH进阶之路]Hibernate基本原理(一) ,小编介绍了Hibernate的基本原理以及它的核心,採用对象化的思维操作关系型数据库. [SSH进阶之路]Hibernate搭建开发环境+简单实例 ...