军事机密 c++ 代码

“军事机密"代码

问题描述:
军方截获的信息由n(n≤100000)个数(每个数最大不超过109)组成,因为是敌国的高端秘密,所以一时不能破获。最原始的想法是对这n个数进行从小到大的排序,每个数对应一个序号,然后进行k(K≤10)次提问,每次提问只是对第i个数是多少感兴趣,现在要求编程完成k次回答。
输入
第一行n,第二行是n个截获的数,接着一行是k,接着是k行提问的数;
输出
k行序号对应的数;

#include <algorithm>
#include <iostream>
#include <cstring>
#include <string>
#include <stack>
#include <cmath>
//可使用万能头文件#include <bits/stdc++.h>,但怕各位同学在用Cena测试时报错 
using namespace std;
int main()
{
 int n,i,j,k;
 cin>>n;
 int a[n];
 for(i=0;i<n;i++)
 {
  cin>>a[i];
 }
 sort(a,a+n);   //sort函数,快排,使用格式是:sort("数组名","数组名"+"数组长度") 
 cin>>k;
 for(i=0;i<k;i++)
 {
  int t;
  cin>>t; 
  cout<<a[t-1]<<endl;  //输入一个输出一个,同学们也可以改成用数组存储的方式,在输完后统一输出 
 }
 return 0;
}

不忘留言点赞哟?

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: DES(Data Encryption Standard)算法是最早的加密标准之一,使用对称密钥加密方法,对数据进行加密以保障数据的机密性、完整性和可用性。C语言可以通过各种方式实现DES算法,这里简要介绍一种常见的实现方法。 首先,需要引入相关的头文件,包括"stdio.h"、"stdlib.h"、"string.h"等。 接下来,需要定义一些常量,如密钥长度、子密钥轮数等。同时,需要定义一些结构体和数组,如: - DESSubKey:存储子密钥的结构体 - IP:初始置换矩阵 - IPInv:初始置换的逆矩阵 - E:扩展矩阵 - S:S盒 - P:P盒 然后,需要实现一些函数,如: - IPPerm:实现初始置换 - IPInvPerm:实现初始置换的逆置换 - ExtendPerm:实现扩展置换 - SBoxPerm:实现S盒置换 - PBoxPerm:实现P盒置换 - KeySchedule:生成子密钥 - DESRound:DES算法单轮加密操作 最后,可以实现一个DES加密函数,接收一个明文和一个密钥,返回加密后的密文。该函数主要包括以下步骤: - 检查明文和密钥长度是否符合要求 - 生成子密钥 - 进行初始置换 - 进行16轮加密 - 进行末置换 以上是一种常见的DES算法实现方法,但由于DES算法已经不再安全,建议使用更为安全的加密算法,如AES(Advanced Encryption Standard)。 ### 回答2: DES(Data Encryption Standard)是一种对称加密算法,它使用同一个密钥进行加密和解密,密钥长度为56位。下面是在C语言中实现DES算法的代码: 首先需要引入DES算法头文件#include "..\..\crypto\des\des.h" 定义DES算法所需的变量:char key[8]; //8字节密钥 unsigned char plaintext[8]; //明文 unsigned char ciphertext[8]; //密文 接下来,使用DES_set_key函数来设置密钥: DES_cblock key32; //key32用于存储56位密钥转换后的64位密钥 unsigned char key[8]; //输入的8字节密钥 memcpy(key, "12345678", 8); //设置密钥的值 memset(key32, 0, 8); //初始化64位密钥 DES_set_key_checked(&key, &key32); //将8字节密钥转换成64位密钥并设置为DES算法的密钥 然后,使用DES_ecb_encrypt函数对明文进行加密: DES_cblock input32; //input32用于存储8字节明文转换后的64位明文 DES_cblock output32; //output32用于存储8字节密文 memset(input32, 0, 8); //初始化64位明文 memcpy(input32, plaintext, 8); //设置明文的值 DES_ecb_encrypt(&input32, &output32, &key32, DES_ENCRYPT); //对明文进行加密 最后,使用DES_ecb_encrypt函数对密文进行解密: DES_cblock input32; //input32用于存储8字节密文转换后的64位密文 DES_cblock output32; //output32用于存储8字节明文 memset(input32, 0, 8); //初始化64位密文 memcpy(input32, ciphertext, 8); //设置密文的值 DES_ecb_encrypt(&input32, &output32, &key32, DES_DECRYPT); //对密文进行解密 通过以上代码,我们就可以在C语言中实现DES算法的加密和解密功能。 ### 回答3: DES算法是对称加密算法中的一种,它使用固定长度的密钥将数据块转换为加密数据块。该算法由IBM研发,在1977年被NSA标准化,成为一种广受使用的加密标准。在实现DES算法时,需要用到C语言进行编程。 在实现DES算法时,需要使用多个函数来完成加密和解密的过程。首先,需要定义几个常量,以及一些用于加密和解密的函数。这些函数包括: 1. IP置换函数(Initial Permutation),用于对64位明文按照规定的顺序重新排列。 2. F函数,用于对32位数据进行压缩和扩展,以及与子密钥进行异或操作和替换操作。 3. PC1函数和PC2函数,分别用于从64位密钥中生成56位子密钥。 4. E置换函数(Expansion Permutation),用于将32位数据扩展为48位数据。 5. P置换函数(Permutation),用于对32位数据按照规定的顺序进行重新排列。 在进行加密和解密的过程中,需要使用的主要函数包括: 1. KeySchedule函数,用于生成16个48位子密钥。 2. DES_Encrypt函数和DES_Decrypt函数,用于分别进行加密和解密的操作。 在具体实现DES算法时,需要参考DES标准的具体实现方式和协议。同时,还需要考虑到实现过程中可能出现的安全漏洞和攻击手段,以及如何进行防御和修补。因此,在进行DES算法的实现时,需要认真学习和理解相关的知识,才能够编写出安全可靠的加密算法代码

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值