博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
base64解密
阅读量:4658 次
发布时间:2019-06-09

本文共 1843 字,大约阅读时间需要 6 分钟。

问题 : base64解密

时间限制: 1 Sec  内存限制: 128 MB

题目描述

Base64编码要求把3个8位字节(3*8=24)转化为4个6位的字节(4*6=24),之后在6位的前面补两个0,形成8位一个字节的形式。 如果剩下的字符不足3个字节,则用0填充,输出字符使用'=',因此编码后输出的文本末尾可能会出现1或2个'='。

为了保证所输出的编码位可读字符,Base64制定了一个编码表,以便进行统一转换。编码表的大小为2^6=64,这也是Base64名称的由来。

如对字符’0’进行Base64加密,则是如下步骤:

字符’0’的二进制为00110000,前六位拿出来,前面补俩个0则是0001100,对应表得字符M。后面不足6位,只有俩位0,拿出来,前面补6个0,则是00000000,对应表得字符A。

由于还有2个6位的字节没显示,则用俩个=字符补充

那么字符0的Base64编码为MA==

现在蛋蛋给了你一段加密后的Base64密文,他说题意隐藏在密文里面,如果你知道了题意,就肯定可以做出本题。密文如下:

d2hhdCBpcyB0aGUgcmVtYWluZGVyIHdoZW4gdGhlIG51bWJlciBpcyBkaXZpZGVkIGJ5IDMwMDg/

输入

第一行一个整数t,代表有t组数据,每组数据输入一个整数x,0<=x<=2^31-1

输出

输出一个整数x,x为答案

样例输入

3012016

样例输出

012016

解题思路:

写一段代码解析出所给密文即可。

解析密文代码:
#include 
#include
int a[100][6];int main(){ int i, j, sum, ans, len; char str[] = "d2hhdCBpcyB0aGUgcmVtYWluZGVyIHdoZW4gdGhlIG51bWJlciBpcyBkaXZpZGVkIGJ5IDMwMDg/"; len = strlen(str); for (i = 0; i < len; i++) { if (str[i] >= 'a' && str[i] <= 'z') str[i] -= 71; else if (str[i]>='A' && str[i] <= 'Z') str[i] -= 65; else if (str[i] >= '0' && str[i] <= '9') str[i] += 4; else if (str[i] == '+') str[i] = 62; else if (str[i] == '/') str[i] = 63; j = 5; while (str[i]) { a[i][j--] = str[i] % 2; str[i] /= 2; } } ans = 0; sum = 0; for(i = 0; i < len; i++) { for(j = 0; j < 6; j++) { ans = ans * 2 + a[i][j]; sum++; if(sum % 8 == 0) { printf("%c", ans); ans = 0; } } } puts(""); return 0;}

what is the remainder when the number is divided by 3008?

#include
int main(){ int m, n; while (~scanf("%d", &m)) { while (m--) { scanf("%d", &n); printf("%d\n", n%3008); } } return 0;}

转载于:https://www.cnblogs.com/lzyws739307453/p/8906280.html

你可能感兴趣的文章
hdu 4542 小明系列故事——未知剩余系
查看>>
Symbian UI 架构分类
查看>>
SVM入门(三)线性分类器Part 2
查看>>
mysql 执行 cannot found mac安装mysql的两种方法(含配置)
查看>>
BZOJ 1984: 月下“毛景树”( 树链剖分 )
查看>>
Properties类、序列化流与反序列化流
查看>>
Swift学习笔记一:与OC的区别
查看>>
七牛容器实操
查看>>
由Java中的Set,List,Map引出的排序技巧
查看>>
一个从四秒到10毫秒,花了1年的算法问题?
查看>>
Java入门的程序汇总
查看>>
理解 YOLO
查看>>
检查Linux文件变更Shell脚本
查看>>
ActiveMQ中JMS的可靠性机制
查看>>
oracle操作字符串:拼接、替换、截取、查找
查看>>
”语义“的理解
查看>>
210. Course Schedule II
查看>>
月薪3000与月薪30000的文案区别
查看>>
使用spring dynamic modules的理由
查看>>
Leetcode 117 Populating Next Right Pointers in Each Node 2
查看>>