字符串转成压缩bcd码
2015-07-24 16:35
260 查看
/*
* 字符串转成压缩bcd码
*/
/**************************************************************/
/*如果要对字符串转换为左靠齐的压缩bcd,则调用asc_to_bcd_left函数*/
char *str1 = "1234567";//str1为需要转换的字符串
int str_len = strlen(str1);
int bcd_len = (str_len+1)/2;
char *bcd = (char *)malloc(bcd_len);
memset(bcd,0,bcd_len);
asc_to_bcd_left(bcd,str1,str_len);//得到的名为bcd的字符串即为需要的压缩bcd码
/**************************************************************/
/**************************************************************/
/*如果要对字符串转换为右靠齐的压缩bcd,则调用asc_to_bcd_right函数*/
char *str1 = "1234567";//str1为需要转换的字符串
int str_len = strlen(str1);
int bcd_len = (str_len+1)/2;
char *bcd = (char *)malloc(bcd_len);
memset(bcd,0,bcd_len);
asc_to_bcd_right(bcd,str1,str_len);//得到的名为bcd的字符串即为需要的压缩bcd码
/**************************************************************/
//具体函数实现如下:
int asc_to_bcd(char * dest,const char *src)//参数dest为
{
unsigned char temp;
while(*src !='\0')
{
temp = *src;
*dest |= ((temp&0xf)<<4);
src++;
temp = *src;
*dest |= (temp&0xf);
src++;
dest++;
}
return 0;
}
//
int asc_to_bcd_right(char *dest,const char *src,int src_len)
//参数dest为申请的存放得到压缩bcd码的字符串,src为需要进行转换的字符串,src_len为src的长度即strlen(src)
{
unsigned char temp;
if((src_len %2) !=0)
{
*dest &= 0;
temp = *src;
*dest |= (temp&0xf);
src++;
dest++;
}
asc_to_bcd(dest,src);
return 0;
}
int asc_to_bcd_left(char *dest,const char *src,int src_len)
//参数dest为申请的存放得到压缩bcd码的字符串,src为需要进行转换的字符串,src_len为src的长度即strlen(src)
{
unsigned char temp;
if((src_len %2) !=0)
{
dest[src_len-1] &=0;
}
asc_to_bcd(dest,src);
return 0;
}
/***以上整理参考自http://blog.csdn.net/nocodelife/article/details/8233082****/
* 字符串转成压缩bcd码
*/
/**************************************************************/
/*如果要对字符串转换为左靠齐的压缩bcd,则调用asc_to_bcd_left函数*/
char *str1 = "1234567";//str1为需要转换的字符串
int str_len = strlen(str1);
int bcd_len = (str_len+1)/2;
char *bcd = (char *)malloc(bcd_len);
memset(bcd,0,bcd_len);
asc_to_bcd_left(bcd,str1,str_len);//得到的名为bcd的字符串即为需要的压缩bcd码
/**************************************************************/
/**************************************************************/
/*如果要对字符串转换为右靠齐的压缩bcd,则调用asc_to_bcd_right函数*/
char *str1 = "1234567";//str1为需要转换的字符串
int str_len = strlen(str1);
int bcd_len = (str_len+1)/2;
char *bcd = (char *)malloc(bcd_len);
memset(bcd,0,bcd_len);
asc_to_bcd_right(bcd,str1,str_len);//得到的名为bcd的字符串即为需要的压缩bcd码
/**************************************************************/
//具体函数实现如下:
int asc_to_bcd(char * dest,const char *src)//参数dest为
{
unsigned char temp;
while(*src !='\0')
{
temp = *src;
*dest |= ((temp&0xf)<<4);
src++;
temp = *src;
*dest |= (temp&0xf);
src++;
dest++;
}
return 0;
}
//
int asc_to_bcd_right(char *dest,const char *src,int src_len)
//参数dest为申请的存放得到压缩bcd码的字符串,src为需要进行转换的字符串,src_len为src的长度即strlen(src)
{
unsigned char temp;
if((src_len %2) !=0)
{
*dest &= 0;
temp = *src;
*dest |= (temp&0xf);
src++;
dest++;
}
asc_to_bcd(dest,src);
return 0;
}
int asc_to_bcd_left(char *dest,const char *src,int src_len)
//参数dest为申请的存放得到压缩bcd码的字符串,src为需要进行转换的字符串,src_len为src的长度即strlen(src)
{
unsigned char temp;
if((src_len %2) !=0)
{
dest[src_len-1] &=0;
}
asc_to_bcd(dest,src);
return 0;
}
/***以上整理参考自http://blog.csdn.net/nocodelife/article/details/8233082****/
相关文章推荐
- 三极管的工作原理
- R RGB color
- zoj1796
- highcharts作图
- 中文乱码问题解决方案汇总
- 反转单链表的几种方法
- hdu 5288 (小技巧)
- Java、HTML、CSS、JSP、JavaScript注释语法
- [LeetCode]Integer to Roman
- 核典型关联分析(KCCA)算法原理
- Linux网络编程之使用TCP传输文件
- 如何取得Spring管理的bean (请用第3种方法):
- 【源代码】java.util.Stack & Queue
- uva 10594 Data Flow (最小费最大流+题目给的数据有错)
- Codeforces Round #313 (Div. 2) C Gerald's Hexagon 计数
- HTML DOM submit() 方法
- jquery ajax备用
- (转)反转单链表的几种方法
- 统计难题
- Espresso——Android测试工具Espresso简介