另外定义了一个数组array[8],用于存放输入的八位二进制数。
2、然后使用了一个for循环语句,用于输入八位二进制数。
3、在Sum函数中,又声明了一个power函数,power函数的作用是求2的n次方。
4、接着,使用了一个for循环语句,i用于控制循环的次数,n从最高的指数7开始每次循环减一,如果指数大于或等于零的,就进行循环。
5、在power函数中,如果b等于零,即指数为零,则返回1,否则就进入一个循环,j用于控制循环次数,有疑问的可以用笔算算乘2的个数对不对,最后将i返回。
6、最后看一下运行的结果。
C语言程序十进制的数转换成八进制的数的办法:
#include <stdio.h>
#include <math.h>
void main()
{
int n,a,sum = 0,i =0
printf("十进制输出一个数n\n")
scanf("%d",&n)
while(n)
{
a = n%8
n = n/8
sum += a*pow(10,i)
i++
}
printf("八进制输出sum:%d",sum)
}
#include <stdio.h>#include <stdbool.h> //true, false
#include <malloc.h>
#include <stdlib.h> //atoi() 字符串转整数
#include <ctype.h> //isalpha(), isdigit()
#include <string.h>
#include <math.h>
/// 输入字符串数字,字符串长度,该数字是几进制数
/// 返回一个十进制数
int StrToInt(char* str, size_t len, size_t base)
{
bool isnegtive = false //该数是否表示负数
int i = 0
if (str[0] == '-')
{
i++
isnegtive = true
}
int num = 0 // 最后计算出的10进制数
for ( i < len ++i)
{
char tem = toupper(str[i]) //若为字母,转换成大写字母,其余不变
int index = 0
if (isalpha(tem)) // 若是字母,转化成对应的10进制数
index = tem - 'A' + 10
else if(isdigit(tem))
index = tem - '0'
else { /* do nothing*/ }
num += index * (int)pow(base, len - 1 - i)
}
return isnegtive ? -num : num
}
/// 把10进制数转换成 指定进制的数
void ToBaseNumber(int orig, size_t base)
{
if (orig == 0)
{
printf("%d\n", 0)
return
}
if (orig < 0)
{
putchar('-')
orig = -orig // 变成正数
}
int* arr = (int* )malloc(sizeof(int) * 16), len = 0, i
while (orig > 0)
{
arr[len++] = orig % base
orig /= base
}
for (i = len - 1 i >= 0 --i)
{
printf("%d", arr[i])
}
putchar('\n')
return
}
int main(int argc, char const *argv[])
{
int T
scanf("%d", &T)
while (T--)
{
char* chs = (char* )malloc(sizeof(char) * 16)
int n, m
scanf("%s %d %d", chs, &n, &m)
int orig = StrToInt(chs, strnlen(chs, 11), n)
ToBaseNumber(orig, m)
}
return 0
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)