7-4 BCD解密 (10分)

BCD数是用一个字节来表达两位十进制的数,每四个比特表示一位。所以如果一个BCD数的十六进制是0x12,它表达的就是十进制的12。但是小明没学过BCD,把所有的BCD数都当作二进制数转换成十进制输出了。于是BCD的0x12被输出成了十进制的18了!

现在,你的程序要读入这个错误的十进制数,然后输出正确的十进制数。提示:你可以把18转换回0x12,然后再转换回12。

(吐槽一下,实际上本题就是10进制数转BCD格式无字母的16进制,不要被题干迷惑)

延伸阅读十进制转化为十六进制C语言详解_学习笔记,仅供参考-CSDN博客_c语言十进制转十六进制

这里先解释下什么是BCD数:

十进制的15    BIN表示为1111(BIN其实就是指二进制数据,逢2就向前写个1,把原本位上变成零,一直按这个规律写下去的数)

BCD其实是指把一个数用多组二进制数来写,比如:

十进制的15    BCD表示为0001 0101

输入格式:
输入在一行中给出一个[0, 153]范围内的正整数,保证能转换回有效的BCD数,也就是说这个整数转换成十六进制时不会出现A-F的数字。

输出格式:
输出对应的十进制数。

输入样例:
18

输出样例:
12

参考代码

#include <stdio.h>

int main()
{
    int n, cnt = 0, t = 1, num = 0;
    int s[2];

    scanf("%d", &n);
    //十进制转十六进制
    while (n)
    {
        s[cnt] = n % 16;
        t *= 16;
        n /= 16;
        cnt++;
    }
    if (s[1] != 0)
        printf("%d", s[1]);
    printf("%d\n", s[0]);

    return 0;
}

另一种做法

#include <stdio.h>
		
int main()
{
	int i,j,k;
	scanf("%d", &i);
	j = i / 16;
	k = i % 16;
	printf("%d\n", j*10+k);
			 
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据你的需求,下面是一个基于FPGA的加密解密一体编码器的简单设计。请注意,以下代码示例是使用Verilog进行描述: ```verilog module EncoderDecoder ( input wire [3:0] input_bcd, // 输入的BCD码 input wire encrypt_btn, // 加密按钮信号 input wire decrypt_btn, // 解密按钮信号 input wire clear_btn, // 清屏按钮信号 output reg [15:0] encrypted_data, // 加密后的数据 output reg [15:0] decrypted_data // 解密后的数据 ); reg [15:0] key = 16'b1010111001100100; // 加密解密密钥为16位二进制码 always @(posedge encrypt_btn or posedge decrypt_btn or posedge clear_btn) begin if (encrypt_btn) begin encrypted_data = input_bcd << 12; // 将BCD码左移12位,补齐至16位 encrypted_data = encrypted_data ^ key; // 使用异或运算进行加密操作 end else if (decrypt_btn) begin decrypted_data = encrypted_data ^ key; // 使用异或运算进行解密操作 end else if (clear_btn) begin encrypted_data = 16'b0; // 清空加密数据 decrypted_data = 16'b0; // 清空解密数据 end end endmodule ``` 在这个示例中,我们定义了一个模块`EncoderDecoder`,它有一个4位的输入`input_bcd`表示要加密或解密BCD码,以及三个输入按钮信号`encrypt_btn`、`decrypt_btn`和`clear_btn`用于控制加密、解密和清屏操作。输出包括加密后的数据`encrypted_data`和解密后的数据`decrypted_data`。 在`always`块中,根据按钮信号的上升沿触发,判断当前操作是加密、解密还是清屏操作。当加密按钮被按下时,我们将输入的BCD码左移12位,使其补齐至16位,并使用异或运算符`^`对其与密钥进行加密操作。当解密按钮被按下时,我们直接将加密后的数据与密钥进行异或运算,得到解密后的结果。当清屏按钮被按下时,将加密数据和解密数据清零。 请注意,以上代码示例只是一个简单的实现,实际的加密解密算法可能更加复杂。你可以根据特定的加密解密算法要求,修改代码以实现更复杂的逻辑。另外,你还需要根据你所使用的FPGA开发板和开发工具,进行适当的约束和综合、布局和布线等步骤,以生成可在FPGA上运行的比特流文件。此外,你还需要添加LCD显示模块和按钮输入模块进行完整的系统设计和实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值