N进制数转换为十进制数

#include "stdio.h"
#include "ctype.h"

long NtoDec(char *str,int B)
{
  int a[50] ={0};
  long value = 0;
  int count = 0;
  while(*str!='\0')  //将字符串中单个字符转换成整数保存到数组
  {
   if(*str>='0'&&*str<='9')
   {
    a[count++] = *str -'0';
   }
   else
   {
    a[count++] = toupper(*str)-'A'+10;  //十六进制字符转换成整数
   }
   str++;
  }

   int count2 = 0;
    for(int i = count - 1;i>=0;i--)//将数组中的数转换成一个整数
   {
    int y = 1;
    for(int j = 0;j < count2 ;j++)
    {
     y*=B;
    }
    value += a[i]*y;
    count2++;
   }
 return value;
}

int main(int argc, char* argv[])
{
   long value = NtoDec("111",2);
   printf("%d\n",value);
  
 return 0;
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 首先将M除以N得到商Q和余R,余R就是转化后的最低位的字。然后将商Q除以N得到新的商和余,余就是转化后的下一位字。如此循环,直到商为0,转化结束。将余倒序排列即为最终结果。 例如,将十进制125转化为八进制: 125 ÷ 8 = 15 … 5,余为5,转化后的最低位为5; 15 ÷ 8 = 1 … 7,余为7,转化后的下一位为7; 1 ÷ 8 = 0 … 1,余为1,转化后的最高位为1。 所以,125的八进制为175。 ### 回答2: 要将一个十进制M转换为N进制,可以使用除N取余法。步骤如下: 1. 将M除以N,得到商Q和余R。 2. 将R作为N进制的一位字。 3. 将Q作为新的十进制,重复步骤1和2,直到Q为0为止。 最后,将得到的余按照颠倒的顺序排列,即为M的N进制表示。 下面以将十进制100转为8进制为例进行演示: 1. 100 ÷ 8 = 12 ... 4,余为4。 2. 12 ÷ 8 = 1 ... 4,余为4。 3. 1 ÷ 8 = 0 ... 1,余为1。 按照颠倒的顺序排列得到4 4 1,所以100的8进制表示为441。 需要注意的是,如果N大于10,那么大于9的余将用字母表示。例如,如果要将十进制100转为16进制,余10将用A表示,余11用B表示,以此类推。 此外,对于小转换,可以将小点后的部分分别乘以N,然后按照上述方法转换为相应的N进制。 ### 回答3: 将十进制M转化为N进制,可以使用“除N取余法”来进行计算。 首先,我们将M除以N,得到商Q和余R1。将R1作为第N进制的最低位。 然后,再将Q除以N,得到新的商Q2和余R2。将R2作为第N进制的次低位。 重复上述步骤,直到商为0为止。每次计算时,将得到的余从低位到高位排列起来即可得到最终的N进制。 举例说明:假设要将十进制123转化为八进制。 首先,将123除以8,商为15,余为3。则八进制的最低位为3。 然后,将15除以8,商为1,余为7。则八进制的次低位为7。 最后,将1除以8,商为0,余为1。则八进制的最高位为1。 将得到的余从低位到高位排列起来,则123的八进制表示为173。 因此,通过“除N取余法”,我们可以将十进制M转化为N进制
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值