代码转换
参考于此 : http://lilongfei1030.blog.163.com/blog/static/860152820079793133315/
为了方便 以后的学习以及使用,本打算自己写一段进制转换的代码, 无意间寻求到此位仁兄的杰作,免去了一番苦敲。
#include<stdio.h>
#define M sizeof(unsigned int)*8
unsigned long n;
int trans1(char a[],int d1) /*将d1进制的num,转换为十进制数s*/
{
int i=0,num,s=0,P=1;
while(P)
{
if(a[i]>='A'&&a[i]<='F') num=a[i]-'0'-7;
else if (a[i]>='a'&&a[i]<='f') num=a[i]-'0'-39;
else if (a[i]>='0'&&a[i]<='9') num=a[i]-'0';
else{
printf("ERROR!\n");
break;
}
if(num<d1)
{
if(i==0) s=num;
else
{
s*=d1;
s+=num*d1;
}
}
else
{
printf("Error!\n"); /*不合规则(d1进制)的num*/
break;
}
if( a[++i]=='\0') P=0;
}
return s;
}
int trans2(unsigned long n, int d, char s[]) /* 将无符号整数n翻译成d(2<=d<=16)进制表示的字符串s */
{
static char digits[] ="0123456789ABCDEF"; /* 十六进制数字的字符 */
char buf[M+1];
int j, i = M;
s[0]='\0';
if(d<2||d>16)
{
s[0]='\0'; /* 不合理的进制,置s为空字符串 */
return 0; /* 不合理的进制,函数返回0 */
}
buf[i]='\0';
do
{
buf[--i]=digits[n%d]; /*译出最低位,对应字符存入对应工作数组中*/
n/=d;
}while(n);
for(j=0;(s[j]=buf[i])!='\0';j++,i++); /*将译出在工作数组中的字符串复制到s */
return j;
}
main()
{
char str[33];
int d1,d2;
while(scanf("%s %d %d",&str,&d1,&d2)!=EOF)
{
n=trans1(str,d1);
if(n&&trans2(n,d2,str)) printf("%s\n",str);
str[0]='\0';
}
}
相关阅读
淘代码如何推广。所谓淘代码,是一种全新的营销方式,其实就是一连串的数字加字母组合,通过淘代码搜索店铺、购买宝贝,是能够获得额外的
这里面有超过50个 user-agent ,包含PC和移动端, 并且可以直接复制粘贴到python代码里. 此方法,是随机其中一个user-agent: # -*
MKV是Matroska的一种媒体文件, Matroska是一种新的多媒体封装格式,它可将多种不同编码的视频及16条以上不同格式的音频和不同语言的
python+opencv计算代码运行时间:time库和opencv自带方
import cv2import time#################
说明: 主要分步骤给出Windows平台下socket编程的一个TCP实例;使用WINDOWS下网络编程规范Winsock完成网络通信; 对程序各部分细节进行