本DES算法,使用了效率很高的C完成。目前,國內(nèi)知名企業(yè)的POS終端中,單DES算法,均是采用這個函數(shù)完成。函數(shù)經(jīng)本站驗證過,可以放心使用。
#include "stdafx.h"
int des(unsigned char *source,unsigned char * dest,unsigned char * inkey, int flg);
int _tmain(int argc, _TCHAR* argv[])
{
unsigned char s[65]="DES算法是這樣工作的:如Mode為加密,則用Key 去把數(shù)據(jù)Data進行加abc";
unsigned char d[65]={0};
unsigned char k[11]="adsss";
unsigned char m[65]={0};
for(int i =0;i<8;i++)
{
??? des(&s[8*i],&d[8*i],k,0);
}
for(int i =0;i<8;i++)
{
??? des(&d[8*i],&m[8*i],k,1);
}
//des(s,d,k,0);
//des(d,m,k2,1);
//printf(d);
char i;
scanf("%c",&i);
return 0;
}
/* ============================================================
des()
Description: DES algorithm,do encript or descript.
============================================================ */
int des(unsigned char *source,unsigned char * dest,unsigned char * inkey, int flg)
{
unsigned char bufout[64],
kwork[56], worka[48], kn[48], buffer[64], key[64],
nbrofshift, temp1, temp2;
int valindex;
register i, j, k, iter;
/* INITIALIZE THE TABLES */
/* Table - s1 */
static unsigned char s1[4][16] = {
14, 4, 13, 1, 2, 15, 11, 8, 3, 10, 6, 12, 5, 9, 0, 7,
0, 15, 7, 4, 14, 2, 13, 1, 10, 6, 12, 11, 9, 5, 3, 8,
4, 1, 14, 8, 13, 6, 2, 11, 15, 12, 9, 7, 3, 10, 5, 0,
15, 12, 8, 2, 4, 9, 1, 7, 5, 11, 3, 14, 10, 0, 6, 13 };
/* Table - s2 */
static unsigned char s2[4][16] = {
15, 1, 8, 14, 6, 11, 3, 4, 9, 7, 2, 13, 12, 0, 5, 10,
3, 13, 4, 7, 15, 2, 8, 14, 12, 0, 1, 10, 6, 9, 11, 5,
0, 14, 7, 11, 10, 4, 13, 1, 5, 8, 12, 6, 9, 3, 2, 15,
13, 8, 10, 1, 3, 15, 4, 2, 11, 6, 7, 12, 0, 5, 14, 9 };
/* Table - s3 */
static unsigned char s3[4][16] = {
10, 0, 9, 14, 6, 3, 15, 5, 1, 13, 12, 7, 11, 4, 2, 8,
13, 7, 0, 9, 3, 4, 6, 10, 2, 8, 5, 14, 12, 11, 15, 1,
13, 6, 4, 9, 8, 15, 3, 0, 11, 1, 2, 12, 5, 10, 14, 7,
1, 10, 13, 0, 6, 9, 8, 7, 4, 15, 14, 3, 11, 5, 2, 12 };
/* Table - s4 */
static unsigned char s4[4][16] = {
7, 13, 14, 3, 0, 6, 9, 10, 1, 2, 8, 5, 11, 12, 4, 15,
13, 8, 11, 5, 6, 15, 0, 3, 4, 7, 2, 12, 1, 10, 14, 9,
10, 6, 9, 0, 12, 11, 7, 13, 15, 1, 3, 14, 5, 2, 8, 4,
3, 15, 0, 6, 10, 1, 13, 8, 9, 4, 5, 11, 12, 7, 2, 14 };
/* Table - s5 */
static unsigned char s5[4][16] = {
2, 12, 4, 1, 7, 10, 11, 6, 8, 5, 3, 15, 13, 0, 14, 9,
14, 11, 2, 12, 4, 7, 13, 1, 5, 0, 15, 10, 3, 9, 8, 6,
4, 2, 1, 11, 10, 13, 7, 8, 15, 9, 12, 5, 6, 3, 0, 14,
11, 8, 12, 7, 1, 14, 2, 13, 6, 15, 0, 9, 10, 4, 5, 3 };
/* Table - s6 */
static unsigned char s6[4][16] = {
12, 1, 10, 15, 9, 2, 6, 8, 0, 13, 3, 4, 14, 7, 5, 11,
10, 15, 4, 2, 7, 12, 9, 5, 6, 1, 13, 14, 0, 11, 3, 8,
9, 14, 15, 5, 2, 8, 12, 3, 7, 0, 4, 10, 1, 13, 11, 6,
4, 3, 2, 12, 9, 5, 15, 10, 11, 14, 1, 7, 6, 0, 8, 13 };
/* Table - s7 */
static unsigned char s7[4][16] = {
4, 11, 2, 14, 15, 0, 8, 13, 3, 12, 9, 7, 5, 10, 6, 1,
13, 0, 11, 7, 4, 9, 1, 10, 14, 3, 5, 12, 2, 15, 8, 6,
1, 4, 11, 13, 12, 3, 7, 14, 10, 15, 6, 8, 0, 5, 9, 2,
6, 11, 13, 8, 1, 4, 10, 7, 9, 5, 0, 15, 14, 2, 3, 12 };
/* Table - s8 */
static unsigned char s8[4][16] = {
13, 2, 8, 4, 6, 15, 11, 1, 10, 9, 3, 14, 5, 0, 12, 7,
1, 15, 13, 8, 10, 3, 7, 4, 12, 5, 6, 11, 0, 14, 9, 2,
7, 11, 4, 1, 9, 12, 14, 2, 0, 6, 10, 13, 15, 3, 5, 8,
2, 1, 14, 7, 4, 10, 8, 13, 15, 12, 9, 0, 3, 5, 6, 11 };
/* Table - Shift */
static unsigned char shift[16] = {
1, 1, 2, 2, 2, 2, 2, 2, 1, 2, 2, 2, 2, 2, 2, 1 };
/* Table - Binary */
static unsigned char binary[64] = {
0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1,
0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1, 1, 1,
1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 1, 0, 1, 0, 1, 1,
1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 1, 1, 1, 1 };
/* MAIN PROCESS */
/* Convert from 64-bit key into 64-byte key */
for (i = 0; i < 8; i++) {
key[8*i] = ((j = *(inkey + i)) / 128) % 2;
key[8*i+1] = (j / 64) % 2;
key[8*i+2] = (j / 32) % 2;
key[8*i+3] = (j / 16) % 2;
key[8*i+4] = (j / 8) % 2;
key[8*i+5] = (j / 4) % 2;
key[8*i+6] = (j / 2) % 2;
key[8*i+7] = j % 2;
}
/* Convert from 64-bit data into 64-byte data */
for (i = 0; i < 8; i++) {
buffer[8*i] = ((j = *(source + i)) / 128) % 2;
buffer[8*i+1] = (j / 64) % 2;
buffer[8*i+2] = (j / 32) % 2;
buffer[8*i+3] = (j / 16) % 2;
buffer[8*i+4] = (j / 8) % 2;
buffer[8*i+5] = (j / 4) % 2;
buffer[8*i+6] = (j / 2) % 2;
buffer[8*i+7] = j % 2;
}
/* Initial Permutation of Data */
bufout[ 0] = buffer[57];
bufout[ 1] = buffer[49];
bufout[ 2] = buffer[41];
bufout[ 3] = buffer[33];
bufout[ 4] = buffer[25];
bufout[ 5] = buffer[17];
bufout[ 6] = buffer[ 9];
bufout[ 7] = buffer[ 1];
bufout[ 8] = buffer[59];
bufout[ 9] = buffer[51];
bufout[10] = buffer[43];
bufout[11] = buffer[35];
bufout[12] = buffer[27];
bufout[13] = buffer[19];
bufout[14] = buffer[11];
bufout[15] = buffer[ 3];
bufout[16] = buffer[61];
bufout[17] = buffer[53];
bufout[18] = buffer[45];
bufout[19] = buffer[37];
bufout[20] = buffer[29];
bufout[21] = buffer[21];
bufout[22] = buffer[13];
bufout[23] = buffer[ 5];
bufout[24] = buffer[63];
bufout[25] = buffer[55];
bufout[26] = buffer[47];
bufout[27] = buffer[39];
bufout[28] = buffer[31];
bufout[29] = buffer[23];
bufout[30] = buffer[15];
bufout[31] = buffer[ 7];
bufout[32] = buffer[56];
bufout[33] = buffer[48];
bufout[34] = buffer[40];
bufout[35] = buffer[32];
bufout[36] = buffer[24];
bufout[37] = buffer[16];
bufout[38] = buffer[ 8];
bufout[39] = buffer[ 0];
bufout[40] = buffer[58];
bufout[41] = buffer[50];
bufout[42] = buffer[42];
bufout[43] = buffer[34];
bufout[44] = buffer[26];
bufout[45] = buffer[18];
bufout[46] = buffer[10];
bufout[47] = buffer[ 2];
bufout[48] = buffer[60];
bufout[49] = buffer[52];
bufout[50] = buffer[44];
bufout[51] = buffer[36];
bufout[52] = buffer[28];
bufout[53] = buffer[20];
bufout[54] = buffer[12];
bufout[55] = buffer[ 4];
bufout[56] = buffer[62];
bufout[57] = buffer[54];
bufout[58] = buffer[46];
bufout[59] = buffer[38];
bufout[60] = buffer[30];
bufout[61] = buffer[22];
bufout[62] = buffer[14];
bufout[63] = buffer[ 6];
/* Initial Permutation of Key */
kwork[ 0] = key[56];
kwork[ 1] = key[48];
kwork[ 2] = key[40];
kwork[ 3] = key[32];
kwork[ 4] = key[24];
kwork[ 5] = key[16];
kwork[ 6] = key[ 8];
kwork[ 7] = key[ 0];
kwork[ 8] = key[57];
kwork[ 9] = key[49];
kwork[10] = key[41];
kwork[11] = key[33];
kwork[12] = key[25];
kwork[13] = key[17];
kwork[14] = key[ 9];
kwork[15] = key[ 1];
kwork[16] = key[58];
kwork[17] = key[50];
kwork[18] = key[42];
kwork[19] = key[34];
kwork[20] = key[26];
kwork[21] = key[18];
kwork[22] = key[10];
kwork[23] = key[ 2];
kwork[24] = key[59];
kwork[25] = key[51];
kwork[26] = key[43];
kwork[27] = key[35];
kwork[28] = key[62];
kwork[29] = key[54];
kwork[30] = key[46];
kwork[31] = key[38];
kwork[32] = key[30];
kwork[33] = key[22];
kwork[34] = key[14];
kwork[35] = key[ 6];
kwork[36] = key[61];
kwork[37] = key[53];
kwork[38] = key[45];
kwork[39] = key[37];
kwork[40] = key[29];
kwork[41] = key[21];
kwork[42] = key[13];
kwork[43] = key[ 5];
kwork[44] = key[60];
kwork[45] = key[52];
kwork[46] = key[44];
kwork[47] = key[36];
kwork[48] = key[28];
kwork[49] = key[20];
kwork[50] = key[12];
kwork[51] = key[ 4];
kwork[52] = key[27];
kwork[53] = key[19];
kwork[54] = key[11];
kwork[55] = key[ 3];
/* 16 Iterations */
for (iter = 1; iter < 17; iter++) {
for (i = 0; i < 32; i++)
{
??? buffer[i] = bufout[32+i];
}
/* Calculation of F(R, K) */
/* Permute - E */
worka[ 0] = buffer[31];
worka[ 1] = buffer[ 0];
worka[ 2] = buffer[ 1];
worka[ 3] = buffer[ 2];
worka[ 4] = buffer[ 3];
worka[ 5] = buffer[ 4];
worka[ 6] = buffer[ 3];
worka[ 7] = buffer[ 4];
worka[ 8] = buffer[ 5];
worka[ 9] = buffer[ 6];
worka[10] = buffer[ 7];
worka[11] = buffer[ 8];
worka[12] = buffer[ 7];
worka[13] = buffer[ 8];
worka[14] = buffer[ 9];
worka[15] = buffer[10];
worka[16] = buffer[11];
worka[17] = buffer[12];
worka[18] = buffer[11];
worka[19] = buffer[12];
worka[20] = buffer[13];
worka[21] = buffer[14];
worka[22] = buffer[15];
worka[23] = buffer[16];
worka[24] = buffer[15];
worka[25] = buffer[16];
worka[26] = buffer[17];
worka[27] = buffer[18];
worka[28] = buffer[19];
worka[29] = buffer[20];
worka[30] = buffer[19];
worka[31] = buffer[20];
worka[32] = buffer[21];
worka[33] = buffer[22];
worka[34] = buffer[23];
worka[35] = buffer[24];
worka[36] = buffer[23];
worka[37] = buffer[24];
worka[38] = buffer[25];
worka[39] = buffer[26];
worka[40] = buffer[27];
worka[41] = buffer[28];
worka[42] = buffer[27];
worka[43] = buffer[28];
worka[44] = buffer[29];
worka[45] = buffer[30];
worka[46] = buffer[31];
worka[47] = buffer[ 0];
/* KS Function Begin */
if (flg) {
nbrofshift = shift[iter-1];
for (i = 0; i < (int) nbrofshift; i++) {
??? temp1 = kwork[0];
??? temp2 = kwork[28];
??? for (j = 0; j < 27; j++) {
???? kwork[j] = kwork[j+1];
???? kwork[j+28] = kwork[j+29];
??? }
??? kwork[27] = temp1;
??? kwork[55] = temp2;
}
} else if (iter > 1) {
nbrofshift = shift[17-iter];
for (i = 0; i < (int) nbrofshift; i++) {
??? temp1 = kwork[27];
??? temp2 = kwork[55];
??? for (j = 27; j > 0; j--) {
???? kwork[j] = kwork[j-1];
???? kwork[j+28] = kwork[j+27];
??? }
??? kwork[0] = temp1;
??? kwork[28] = temp2;
}
}
/* Permute kwork - PC2 */
kn[ 0] = kwork[13];
kn[ 1] = kwork[16];
kn[ 2] = kwork[10];
kn[ 3] = kwork[23];
kn[ 4] = kwork[ 0];
kn[ 5] = kwork[ 4];
kn[ 6] = kwork[ 2];
kn[ 7] = kwork[27];
kn[ 8] = kwork[14];
kn[ 9] = kwork[ 5];
kn[10] = kwork[20];
kn[11] = kwork[ 9];
kn[12] = kwork[22];
kn[13] = kwork[18];
kn[14] = kwork[11];
kn[15] = kwork[ 3];
kn[16] = kwork[25];
kn[17] = kwork[ 7];
kn[18] = kwork[15];
kn[19] = kwork[ 6];
kn[20] = kwork[26];
kn[21] = kwork[19];
kn[22] = kwork[12];
kn[23] = kwork[ 1];
kn[24] = kwork[40];
kn[25] = kwork[51];
kn[26] = kwork[30];
kn[27] = kwork[36];
kn[28] = kwork[46];
kn[29] = kwork[54];
kn[30] = kwork[29];
kn[31] = kwork[39];
kn[32] = kwork[50];
kn[33] = kwork[44];
kn[34] = kwork[32];
kn[35] = kwork[47];
kn[36] = kwork[43];
kn[37] = kwork[48];
kn[38] = kwork[38];
kn[39] = kwork[55];
kn[40] = kwork[33];
kn[41] = kwork[52];
kn[42] = kwork[45];
kn[43] = kwork[41];
kn[44] = kwork[49];
kn[45] = kwork[35];
kn[46] = kwork[28];
kn[47] = kwork[31];
/* KS Function End */
/* worka XOR kn */
for (i = 0; i < 48; i++)
worka[i] = worka[i] ^ kn[i];
/* 8 s-functions */
valindex = s1[2*worka[ 0]+worka[ 5]]
[2*(2*(2*worka[ 1]+worka[ 2])+
worka[ 3])+worka[ 4]];
valindex = valindex * 4;
kn[ 0] = binary[0+valindex];
kn[ 1] = binary[1+valindex];
kn[ 2] = binary[2+valindex];
kn[ 3] = binary[3+valindex];
valindex = s2[2*worka[ 6]+worka[11]]
[2*(2*(2*worka[ 7]+worka[ 8])+
worka[ 9])+worka[10]];
valindex = valindex * 4;
kn[ 4] = binary[0+valindex];
kn[ 5] = binary[1+valindex];
kn[ 6] = binary[2+valindex];
kn[ 7] = binary[3+valindex];
valindex = s3[2*worka[12]+worka[17]]
[2*(2*(2*worka[13]+worka[14])+
worka[15])+worka[16]];
valindex = valindex * 4;
kn[ 8] = binary[0+valindex];
kn[ 9] = binary[1+valindex];
kn[10] = binary[2+valindex];
kn[11] = binary[3+valindex];
valindex = s4[2*worka[18]+worka[23]]
[2*(2*(2*worka[19]+worka[20])+
worka[21])+worka[22]];
valindex = valindex * 4;
kn[12] = binary[0+valindex];
kn[13] = binary[1+valindex];
kn[14] = binary[2+valindex];
kn[15] = binary[3+valindex];
valindex = s5[2*worka[24]+worka[29]]
[2*(2*(2*worka[25]+worka[26])+
worka[27])+worka[28]];
valindex = valindex * 4;
kn[16] = binary[0+valindex];
kn[17] = binary[1+valindex];
kn[18] = binary[2+valindex];
kn[19] = binary[3+valindex];
valindex = s6[2*worka[30]+worka[35]]
[2*(2*(2*worka[31]+worka[32])+
worka[33])+worka[34]];
valindex = valindex * 4;
kn[20] = binary[0+valindex];
kn[21] = binary[1+valindex];
kn[22] = binary[2+valindex];
kn[23] = binary[3+valindex];
valindex = s7[2*worka[36]+worka[41]]
[2*(2*(2*worka[37]+worka[38])+
worka[39])+worka[40]];
valindex = valindex * 4;
kn[24] = binary[0+valindex];
kn[25] = binary[1+valindex];
kn[26] = binary[2+valindex];
kn[27] = binary[3+valindex];
valindex = s8[2*worka[42]+worka[47]]
[2*(2*(2*worka[43]+worka[44])+
worka[45])+worka[46]];
valindex = valindex * 4;
kn[28] = binary[0+valindex];
kn[29] = binary[1+valindex];
kn[30] = binary[2+valindex];
kn[31] = binary[3+valindex];
/* Permute - P */
worka[ 0] = kn[15];
worka[ 1] = kn[ 6];
worka[ 2] = kn[19];
worka[ 3] = kn[20];
worka[ 4] = kn[28];
worka[ 5] = kn[11];
worka[ 6] = kn[27];
worka[ 7] = kn[16];
worka[ 8] = kn[ 0];
worka[ 9] = kn[14];
worka[10] = kn[22];
worka[11] = kn[25];
worka[12] = kn[ 4];
worka[13] = kn[17];
worka[14] = kn[30];
worka[15] = kn[ 9];
worka[16] = kn[ 1];
worka[17] = kn[ 7];
worka[18] = kn[23];
worka[19] = kn[13];
worka[20] = kn[31];
worka[21] = kn[26];
worka[22] = kn[ 2];
worka[23] = kn[ 8];
worka[24] = kn[18];
worka[25] = kn[12];
worka[26] = kn[29];
worka[27] = kn[ 5];
worka[28] = kn[21];
worka[29] = kn[10];
worka[30] = kn[ 3];
worka[31] = kn[24];
/* bufout XOR worka */
for (i = 0; i < 32; i++) {
??? bufout[i+32] = bufout[i] ^ worka[i];
??? bufout[i] = buffer[i];
}
} /* End of Iter */
/* Prepare Output */
for (i = 0; i < 32; i++) {
??? j = bufout[i];
??? bufout[i] = bufout[32+i];
??? bufout[32+i] = j;
}
/* Inverse Initial Permutation */
buffer[ 0] = bufout[39];
buffer[ 1] = bufout[ 7];
buffer[ 2] = bufout[47];
buffer[ 3] = bufout[15];
buffer[ 4] = bufout[55];
buffer[ 5] = bufout[23];
buffer[ 6] = bufout[63];
buffer[ 7] = bufout[31];
buffer[ 8] = bufout[38];
buffer[ 9] = bufout[ 6];
buffer[10] = bufout[46];
buffer[11] = bufout[14];
buffer[12] = bufout[54];
buffer[13] = bufout[22];
buffer[14] = bufout[62];
buffer[15] = bufout[30];
buffer[16] = bufout[37];
buffer[17] = bufout[ 5];
buffer[18] = bufout[45];
buffer[19] = bufout[13];
buffer[20] = bufout[53];
buffer[21] = bufout[21];
buffer[22] = bufout[61];
buffer[23] = bufout[29];
buffer[24] = bufout[36];
buffer[25] = bufout[ 4];
buffer[26] = bufout[44];
buffer[27] = bufout[12];
buffer[28] = bufout[52];
buffer[29] = bufout[20];
buffer[30] = bufout[60];
buffer[31] = bufout[28];
buffer[32] = bufout[35];
buffer[33] = bufout[ 3];
buffer[34] = bufout[43];
buffer[35] = bufout[11];
buffer[36] = bufout[51];
buffer[37] = bufout[19];
buffer[38] = bufout[59];
buffer[39] = bufout[27];
buffer[40] = bufout[34];
buffer[41] = bufout[ 2];
buffer[42] = bufout[42];
buffer[43] = bufout[10];
buffer[44] = bufout[50];
buffer[45] = bufout[18];
buffer[46] = bufout[58];
buffer[47] = bufout[26];
buffer[48] = bufout[33];
buffer[49] = bufout[ 1];
buffer[50] = bufout[41];
buffer[51] = bufout[ 9];
buffer[52] = bufout[49];
buffer[53] = bufout[17];
buffer[54] = bufout[57];
buffer[55] = bufout[25];
buffer[56] = bufout[32];
buffer[57] = bufout[ 0];
buffer[58] = bufout[40];
buffer[59] = bufout[ 8];
buffer[60] = bufout[48];
buffer[61] = bufout[16];
buffer[62] = bufout[56];
buffer[63] = bufout[24];
j = 0;
for (i = 0; i < 8; i++) {
??? *(dest + i) = 0x00;
??? for (k = 0; k < 7; k++)
??? *(dest + i) = ((*(dest + i)) + buffer[j+k]) * 2;
??? *(dest + i) = *(dest + i) + buffer[j+7];
??? j += 8;
}
return 0;
}
用C語言實現(xiàn)DES算法
- 算法(90510)
- C語言(123585)
相關(guān)推薦
80c51單片機使用c語言實現(xiàn)P2接口
80c51單片機使用c語言實現(xiàn)P2接口led燈依次點亮周期循環(huán)#include unsigned int a ;unsigned char i ;void main(){while(1){ for(i=0;i
2021-07-15 09:38:29
DES加密算法是什么
一、加密算法1、 DES加密算法DES數(shù)據(jù)加密標(biāo)準(zhǔn),是一種使用密鑰加密的塊算法。DES中的密鑰key為8個字節(jié)64位,但每第8個為校驗位不參與運算,所以有效密鑰只有56位,DATA為8個字節(jié)64位
2021-07-22 09:13:59
用c語言實現(xiàn)的pid算法
[table][tr][td] pid算法應(yīng)該算是所以算法中最穩(wěn)定最可靠最簡單的算法,在庫函數(shù)中添加這種算法對實際控制的時延有非常大的幫助。 全部資料51hei下載地址: C語言PID算法.doc
2018-07-02 06:27:57
用易語言實現(xiàn)的串口控制設(shè)備和從外部采集數(shù)據(jù)的范例
用易語言實現(xiàn)的串口控制設(shè)備和從外部采集數(shù)據(jù)的范例
2016-10-06 13:14:37
用易語言實現(xiàn)的串口控制設(shè)備和從外部采集數(shù)據(jù)的范例
用易語言實現(xiàn)的串口控制設(shè)備和從外部采集數(shù)據(jù)的范例
2016-10-06 17:04:00
ADUC7061如何使用C語言實現(xiàn)EEPROM功能?
我使用ADUC7061做的信號采集,現(xiàn)在客戶需要實現(xiàn)EEPROM功能來保存3-5個數(shù)據(jù),請問如何使用C語言實現(xiàn)?不使用外部EEPROM 專用IC。
2024-01-12 06:56:45
PID控制算法的C語言實現(xiàn)
網(wǎng)上的資料,程序原理與實現(xiàn)上主要參考了“PID控制算法的C語言實現(xiàn).(絕對的好東西)”。本次PID主要是通過固態(tài)繼電器控制加熱片進行加熱,溫度探測使用的DS18B20,穩(wěn)定后在0.5
2022-01-14 09:01:15
nodemcu用lua語言實現(xiàn)延遲呼吸燈
nodemcu用lua語言實現(xiàn)延遲呼吸燈。做過單片機,用慣了c語言的,都喜歡用while或for來實現(xiàn)延遲,但是lua語言用while循環(huán)就沒用了,因為c語言是同步語言,lua是異步語言。同步和異步
2021-11-01 06:56:49
什么是PID控制算法?PID控制算法C語言是如何實現(xiàn)的?
什么是PID控制算法?PID控制算法C語言是如何實現(xiàn)的?特殊情況下的控制算法該如何去調(diào)整?比例、積分、微分三個環(huán)節(jié)的控制作用分別是什么?
2021-06-29 09:24:32
關(guān)于10大C語言基礎(chǔ)算法
數(shù)列,又稱黃金分割數(shù)列,指的是這樣一個數(shù)列:1、1、2、3、5、8、13、21。C語言實現(xiàn)的代碼如下:/* Displaying Fibonacci sequence up to nth term
2020-04-29 14:30:27
單片機C語言實例有哪些
單片機C語言實例(400例)/單片機C語言實例(400例)/1-IO輸出-點亮1個LED燈方法1/單片機C語言實例(400例)/1-IO輸出-點亮1個LED燈方法1/IO輸出.Opt單片機C語言實
2021-07-15 10:06:30
基于FPGA的圖像邊緣檢測系統(tǒng)設(shè)計,用VHDL語言實現(xiàn)該怎么做?
不知道有沒有大神做過:基于FPGA的圖像邊緣檢測系統(tǒng)設(shè)計,用VHDL語言實現(xiàn)
2018-05-10 00:22:07
基于Miracl庫的中國剩余定理C語言實現(xiàn)資料分享
/article/details/102755680針對大數(shù)的中國剩余定理C語言實現(xiàn)一、算法介紹二、代碼實現(xiàn)三、結(jié)果截圖一、算法介紹中國剩余定理又稱孫子定理,是中國人在古代數(shù)學(xué)上的一點智慧果實(fina...
2021-07-02 06:18:14
如何使用c語言實現(xiàn)LED流水燈
單片機實驗:使用c語言實現(xiàn)LED流水燈目的:實現(xiàn)一個簡單的流水燈程序仿真軟件:Portues編程軟件:KeilPortues 原理圖繪制:需要用到的模塊:單片機:AT89C51電容
2021-11-30 07:52:33
如何用C語言實現(xiàn)一個簡單的一元線性回歸算法
今天我們用C語言實現(xiàn)一個簡單的線性回歸算法;在代碼前面我們在回顧一下線性回歸。線性回歸是回歸問題中的一種,線性回歸假設(shè)目標(biāo)值與特征是線性相關(guān)的,即滿足一個多元一次方程式。通過構(gòu)建損失函數(shù),來求解損失
2021-07-20 06:34:33
如何用C語言實現(xiàn)字符數(shù)組轉(zhuǎn)換為16進制數(shù)組?
如何用C語言實現(xiàn)字符數(shù)組轉(zhuǎn)換為16進制數(shù)組?
2021-11-03 07:47:14
如何用C語言實現(xiàn)面向?qū)ο缶幊?/a>
1 用C語言實現(xiàn)面向?qū)ο缶幊蘂OF的《設(shè)計模式》一書的副標(biāo)題叫做“可復(fù)用面向?qū)ο筌浖幕A(chǔ)”,從標(biāo)題就能看出面向?qū)ο笫窃O(shè)計模式基本思想。由于C語言并不是面向?qū)ο蟮?b class="flag-6" style="color: red">語言,C語言沒有直接提供封裝、繼承
2021-07-12 07:24:18
如何用匯編語言實現(xiàn)DES加密算法
利用匯編語言實現(xiàn)DES加密算法DES算法是一種數(shù)據(jù)加密算法。自從1977年公布以來,一直是國際上的商用保密通信和計算機通信的最常用的加密標(biāo)準(zhǔn)。DES算法的實現(xiàn)一般用高級語言。關(guān)鍵詞:加密算法 DES
2009-04-07 09:25:29
嵌入式平臺C語言實現(xiàn)二階濾波器的方法
最近想從嵌入式平臺上用C語言實現(xiàn)二階濾波器,于是先從Matlab上驗證二階濾波器公式,再編寫C語言來驗證。算法移植(實現(xiàn)過程)①先用Matlab自帶公式的二階濾波器實現(xiàn);②運用公式Matlab實現(xiàn)
2021-12-15 09:12:52
快速傅里葉變換C語言實現(xiàn)
快速傅里葉變換C語言實現(xiàn) 模擬采樣進行頻譜分析FFT是DFT的快速算法用于分析確定信號(時間連續(xù)可積信號、不一定是周期信號)的頻率(或相位、此處不研究相位)成分,且傅里葉變換對應(yīng)的ω\omega
2021-07-20 06:01:26
怎樣用C語言實現(xiàn)三種模式的切換
怎樣用C語言實現(xiàn)三種模式的切換,并且在進入一種模式后,可以實現(xiàn)假的死循環(huán)。當(dāng)模式切換時,進入另一種模式的死循環(huán)。(注:用于51單片機)
2015-04-30 00:44:18
怎樣用C語言實現(xiàn)流水燈高亮度在前循環(huán),低亮度在依次點亮不滅
怎樣用C語言實現(xiàn)流水燈高亮度在前循環(huán),低亮度在依次點亮不滅
2015-11-10 01:17:38
最全PID控制算法的C語言實現(xiàn)(轉(zhuǎn))
最近項目中用到PID控制算法,查了很多資料,資料上說的一塌糊涂,什么手動調(diào)節(jié)啊?說的和沒說一樣,對于剛接觸PID的人根本弄不明白。當(dāng)我看到《最全PID控制算法的C語言實現(xiàn)》的時候,只看了前面一部分就搞明白了,里面還有C語言代碼。很好的一份資料,希望對大家有用。
2015-06-01 10:53:00
有誰用LabView實現(xiàn)過 PBKDF2 / HMAC-SHA256算法嗎?
我在其他網(wǎng)站上看到有通過C語言實現(xiàn) PBKDF2 / HMAC-SHA256 的,想知道有誰用LabView實現(xiàn)過這個算法哇?
2017-05-28 21:23:25
求大佬分享51單片機用C語言實現(xiàn)交通燈源程序?qū)嵱?xùn)QY-KP1
求大佬分享51單片機用C語言實現(xiàn)交通燈源程序?qū)嵱?xùn)QY-KP1
2021-10-12 07:48:05
經(jīng)典算法大全(51個C語言算法+單片機常用算法+機器學(xué)十大算法)
啟發(fā)式搜索算法 九、圖像特征提取與匹配之SIFT算法 九(續(xù))、sift算法的編譯與實現(xiàn) 九(再續(xù))、教你一步一步用c語言實現(xiàn)sift算法、上九(再續(xù))、教你一步一步用c語言實現(xiàn)sift算法、下
2018-10-23 14:31:12
用FPGA實現(xiàn)DES算法的密鑰簡化算法
介紹DES的密鑰算法,提出一種用預(yù)計算簡化密鑰計算的方法并公布了預(yù)計算的C語言源程序。這種方法對 DES的硬件實現(xiàn)有非常好的簡化效果。
2009-04-07 09:41:5514
C語言實現(xiàn)數(shù)字信號處理算法
C語言實現(xiàn)數(shù)字信號處理算法附錄A1 BC下復(fù)數(shù)類型的實現(xiàn)1、利用BC提供的復(fù)數(shù)支持//BC中使用復(fù)數(shù)類型使用示例(ComplexUse.Cpp文件)#include <iostream.h>#include <complex.h>
2009-05-10 09:55:0867
基于FPGA的DES 算法S盒的優(yōu)化設(shè)計
為了滿足工程上實時加密和密鑰安全管理的需要,越來越多的加密算法開始采用可編程邏輯器件實現(xiàn)。數(shù)據(jù)加密標(biāo)準(zhǔn)DES 及其變形3-DES,是當(dāng)前應(yīng)用最為廣泛的加密算法。在算法中,S
2009-05-18 13:22:4613
CRC算法原理及C語言實現(xiàn)
CRC算法原理及C語言實現(xiàn):本文從理論上推導(dǎo)出CRC 算法實現(xiàn)原理,給出三種分別適應(yīng)不同計算機或微控制器硬件環(huán)境的C 語言程序。讀者更能根據(jù)本算法原理,用不同的語言編寫出獨特
2009-09-23 23:38:5031
用JAVA語言實現(xiàn)RSA公鑰密碼算法
用JAVA語言實現(xiàn)RSA公鑰密碼算法:本文闡述了公開密鑰密碼體制RSA算法的原理及實現(xiàn)技術(shù)。并在此基礎(chǔ)上,給出了JAVA語言實現(xiàn)的RSA算法源代碼。關(guān)鍵詞:ILSA體制;公鑰;密鑰
2010-02-10 10:27:1558
3-DES算法的FPGA高速實現(xiàn)
摘要:介紹3-DES算法的概要;以Xilinx公司SPARTANII結(jié)構(gòu)的XC2S100為例,闡述用FPGA高速實現(xiàn)3-DES算法的設(shè)計要點及關(guān)鍵部分的設(shè)計。引 言
2006-03-13 19:36:42651
des算法原理
des算法原理
DES算法全稱為Data Encryption Standard,即數(shù)據(jù)加密算法,它是IBM公司于1975年研究成功并公開發(fā)表的。DES算法的入口參數(shù)有三個:Key、Data、Mode。其中Key
2008-01-16 10:07:262471
用C語言實現(xiàn)FFT算法
用C語言實現(xiàn)FFT算法
/*****************fft programe*********************/#include "typedef.h" #include "math.h"
struct compx EE(struct compx
2008-10-30 13:39:566179
利用匯編語言實現(xiàn)DES加密算法
利用匯編語言實現(xiàn)DES加密算法
DES算法是一種數(shù)據(jù)加密算法。自從1977年公布以來,一直是國際上的商用保密通信和計算機通信的最常用的加密標(biāo)準(zhǔn)。DES算法的實現(xiàn)一般用高級
2009-04-07 09:24:511130
3DES算法的FPGA高速實現(xiàn)
摘要:介紹3-DES算法的概要;以Xilinx公司SPARTANII結(jié)構(gòu)的XC2S100為例,闡述用FPGA高速實現(xiàn)3-DES算法的設(shè)計要點及關(guān)鍵部分的設(shè)計。
關(guān)鍵詞:3-DES
2009-06-20 14:22:001317
3DES加密算法的原理及FPGA設(shè)計實現(xiàn)
摘要: 介紹了3DES加密算法的原理并詳盡描述了該算法的FPGA設(shè)計實現(xiàn)。采用了狀態(tài)機和流水線技術(shù),使得在面積和速度上達到最佳優(yōu)化;添加了輸入和輸出接口的設(shè)計以增強該算法應(yīng)用的靈活性。各模塊均用硬件
2017-11-06 11:10:094
c語言實現(xiàn)des加密算法詳細過程
摘要:DES算法為密碼體制中的對稱密碼體制,又被稱為美國數(shù)據(jù)加密標(biāo)準(zhǔn),是1972年美國IBM公司研制的對稱密碼體制加密算法。明文按64位進行分組,密鑰長64位,密鑰事實上是56位參與DES運算。它將64位輸入經(jīng)過一系列變換得到64位的輸出。下面我們來看看c語言實現(xiàn)des加密算法詳細過程。
2017-12-10 11:28:5734523
使用C語言實現(xiàn)51單片機中的PID算法代碼免費下載
本文檔的主要內(nèi)容詳細介紹的是使用使用C語言實現(xiàn)51單片機中的PID算法代碼免費下載。
2019-09-25 17:17:0030
如何使用C語言實現(xiàn)NURBS曲面的算法研仿真說明
討論了一種生成NURBS曲面的算法,用C語言實現(xiàn)了該算法,并利用MATLAB進行仿真對該算法進行驗證。在算法中討論了曲面及其等距面生成方法以及曲面生成技術(shù)中相關(guān)的一些技術(shù),如曲線段問參數(shù)過渡、曲面生成模式、曲面生成的實時性、改變曲面的形狀等。仿真結(jié)果證明了算法的有效性。
2019-11-22 16:52:003
使用C語言實現(xiàn)萬年歷星期速算法的源代碼免費下載
本文檔的主要內(nèi)容詳細介紹的是使用C語言實現(xiàn)萬年歷星期速算法的源代碼免費下載。
2020-01-24 17:19:002701
如何使用C語言實現(xiàn)PID控制算法
最近兩天在考慮一般控制算法的 C 語言實現(xiàn)問題,發(fā)現(xiàn)網(wǎng)絡(luò)上尚沒有一套完整的比較體系的講解。于是總結(jié)了幾天,整理一套思路分享給大家。 在工業(yè)應(yīng)用中 PID 及其衍生算法是應(yīng)用最廣泛的算法之一
2020-09-21 08:00:007
廣義互相關(guān)算法用FFT加速的C語言實現(xiàn)
廣義互相關(guān)算法如何用C語言實現(xiàn)?在聲音測距的原理中,我們可以利用麥克風(fēng)對采集的聲音信號利用互相關(guān)算法測出音源與麥克風(fēng)距離的差值,而大致求出音源的方位。這也是第十五屆智能車競賽聲音
2022-01-13 13:24:225
怎么用C語言實現(xiàn)多態(tài)
這里我想主要介紹下在C語言中是如何實現(xiàn)的面向?qū)ο蟆V懒薈語言實現(xiàn)面向?qū)ο蟮姆绞剑覀冊俾?lián)想下,C++中的class的運行原理是什么?
2022-10-12 09:12:271578
評論
查看更多