c入门番外篇——我们用密码交流怎么样?

最近看到一个关于华罗庚先生的小故事。一九二九年,苏家驹先生在上海《学艺》七卷上发表了《代数式的五次方程之解法》,华罗庚先生发现此文在一个十二阶段的行列式中有计算差错,便写出《苏家驹之代数解法不能成立的理由》的论文,于一九三O年发表于上海《科学》杂志,论文引起了清华大学熊庆来教授的重视,得意后续进入清华。那一年他才20岁,因为家境贫寒,从高中辍学多年。

看见师弟埋头搞一些数字,我便问道:"师弟,你在破解数学难题?"

师弟:"倒不是什么数学难题?是在翻译密码?"

我好奇道:"密码?什么密码?"

师弟:"程夏同学,不知道最近在玩什么游戏,给我了一张密码表,然后发了我一些数字,我再翻译看看都是些啥。"

我:"为什么不借助机器自动翻译呢?"

师弟:"我怎么忘记了这事。我应该写个程序,一劳永逸的。"

密码破解

密码表如下

c 复制代码
以0开始
1 a
2 b
3 c
4 d
5 e
6 f
7 g
8 h
9 i

以00开始
1 j
2 k
3 l
4 m
5 n
6 o
7 p
8 q
9 r

以000开始
1 s
2 t
3 u
4 v
5 w
6 x
7 y
8 z

举例说明:

加密报文: 012300123000123 翻译后: abcjklstu

现程夏发的信息是: 00010550007006000320064699600050030920090100900070100022080090550074

她的实际意思是什么呢?

c 复制代码
#include <stdio.h>
#include <string.h>

char table[3][10] = {
   //0    1    2    3    4    5    6    7    8    9
    '1', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i',
    '2', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r',
    '3', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0'
};

void decode(char *secret)
{
    int i;
    int zero_num = 0;

    for(i=0; i<strlen(secret); i++) {
        if(secret[i] == '0') {
            zero_num++;
            if (i>=1 && secret[i-1]!='0') {
                zero_num = 1;
            }
            continue;
        }

        printf("%c", table[zero_num-1][secret[i]-'0']);
    }

}

int main()
{

    char *secret = "00010550007006000320064699600050030920090100900070100022080090550074";
    decode(secret);
    return 0;
}
相关推荐
楼台的春风1 小时前
【MCU驱动开发概述】
c语言·驱动开发·单片机·嵌入式硬件·mcu·自动驾驶·嵌入式
黑子哥呢?1 小时前
安装Bash completion解决tab不能补全问题
开发语言·bash
青龙小码农1 小时前
yum报错:bash: /usr/bin/yum: /usr/bin/python: 坏的解释器:没有那个文件或目录
开发语言·python·bash·liunx
大数据追光猿1 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!1 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
夏末秋也凉1 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode
南宫生1 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode
柠石榴2 小时前
【练习】【回溯No.1】力扣 77. 组合
c++·算法·leetcode·回溯
Leuanghing2 小时前
【Leetcode】11. 盛最多水的容器
python·算法·leetcode
qy发大财2 小时前
加油站(力扣134)
算法·leetcode·职场和发展