NOI1.8.25 螺旋加密 题解(C++)

NOI1.8.25 螺旋加密 题解(C++)

这题太坑了吧,给大家看一下我的提交记录:
在这里插入图片描述
这是我两个月前刷的这一题。写第7次的时候才对啊。。。
在这里插入图片描述
直接上题目吧:

题目

总Time Limit: 1000ms Memory Limit: 65536kB
Description
Chip和Dale发明了一种文本信息加密技术。他们事先秘密约定好矩阵的行数和列数。接着,将字符按如下方式编码:
1 . 所有文本只包含大写字母和空格。
2 . 每个字符均赋予一个数值:空格=0,A=1,B=2,……,Y=25,Z=26。
按照下图所示的方式,将每个字符对应数值的5位二进制数依次填入矩阵。最后用0将矩阵补充完整。例如,对于信息“ACM”,行列数均为4时,矩阵将被填充为:
在这里插入图片描述
将矩阵中的数字按行连起来形成数字串,完成加密。例子中的信息最终会被加密为:0000110100101100。

Input
一行。首先是两个整数R(1≤R≤20)和C(1≤C≤20),表示行数和列数。之后是一个只包含大写字母和空格的字符串。字符串的长度≤(R*C)/5。R和C之间以及C和字符串之间均用单个空格隔开。

Output
一行,为加密后的二进制串。注意你可能需要用0将矩阵补充完整。

Sample Input
4 4 ACM
Sample Output
0000110100101100

思路

作者很弱,但是这题真的能模拟,真的能模拟。。。只不过很麻烦就是了。

带注释AC代码:

#include<bits/stdc++.h> 
using namespace std;
int m[25][25];//根据题意,也用二维数组模拟
bool m1[25][25];//m1用来标注这个格子是否走过
char l[405];//储存字符串
int row,col,y,len,ans = 0;
void change(int n,int p){
   
	int s = p-4;
	while(p>=s){
   
		l[p] = n%2+0x30;//把二进制填充5位到l,记住l是字符数组 
		n/=2;
		p--;
	}
}//10进制转2进制 
bool pd(int x,int y){
   
	
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值