数据转换-整数字节数组

0. 在openEuler(推荐)或Ubuntu或Windows(不推荐)中完成下面任务

1 参考《GMT 0009-2012 SM2密码算法使用规范》第6节“数据转换” 在utils.h和utils.c中完成整数与8位字节串的转换功能

2 并写出测试代码测试上述函数

3 提交代码(或代码链接)和运行结果


1 参考《GMT 0009-2012 SM2密码算法使用规范》第6节“数据转换” 在utils.h和utils.c中完成整数与8位字节串的转换功能

代码部分如下:
utils.h

#ifndef _UTIL_H_
#define _UTIL_H_

//char Hex2Char(int i);
//int Char2Hex(char c);

int Hex2Char(int fromi,char * toc);
int Char2Hex(char fromc,int * toi);

int Bitstr2ByteArr(char * bs,char * ba);
int ByteArr2Bitstr(char * ba,char * bs);

int Int2ByteArr(int i,char * ba);
int ByteArr2Int(char * ba,int * i);

#endif

utils.c

#include<stdio.h>
#include"utils.h"
#include<string.h>
int Hex2Char(int fromi,char *toc)
{
    if(fromi>=0&&fromi<=9)
    {
        *toc= fromi+'0';
    } 
    else if(fromi>=10&&fromi<=15)
    {
        *toc = fromi+'A'-10;
    }
    else
    {
        printf("输入的16进制数据不正确!");
     }
    return 0;
}
int Char2Hex(char fromc,int *toi)
{
    if(fromc>='0'&& fromc<='9')
    {
             *toi= fromc-'0';
    }
    else if(fromc>='A'&& fromc<='F')
    {
             *toi= fromc-'A'+10;
    
        }
        else 
        {
            printf("输入的16进制字符不正确");
        }
    return 0;
}

int INT2ByteArr(int i,char *ba){
   int j;
   int a;
   int sum=0;
   int k=i;
   for(j=0;;j++)
   {
     k=k/16;
     if(k!=0)
      sum++;
     else
       break;
   }
   for(j=sum;j>=0;j--){
     a = i%16;
     Hex2Char(a,&ba[j]);
     i=i/16;   

   }
   ba[sum+1]='';


}
int ByteArr2INT(char *ba,int *i)
{
   int len;
   int j;
   int n=0;
   *i=0;
   len = strlen(ba);
   for(j=0;j<len;j++)
   {
      Char2Hex(ba[j],&n);
      //printf("%d
",n);
      *i=(*i)*16+n;  

   }
   
}

main.c

#include<stdio.h>
#include"utils.h"
int main(){
   //把整型数字转化为字节数组
  int p;
  char bytearr[100];
  printf("请输入一个整型数字
");
  scanf("%d",&p);
  printf("把整型数转化为字节数组
");
  INT2ByteArr(p,bytearr);
  printf("字节数组为%s
",bytearr);
 
  //把字节数组转化为整型数字
  
  char barr[100];
  int h;
  printf("请输入一个字节数组:");
  scanf("%s",barr);
  printf("把字节数组转化为整型数字:");
  ByteArr2INT(barr,&h);
  printf("%d
",h);
   

}

3 提交代码(或代码链接)和运行结果

运行结果如下:

posted @ 2022-06-16 18:13  20191330雷清逸  阅读(74)  评论(0编辑  收藏  举报