编一个程序,其中调用函数
void tran(int n, int d)
用于将十进制数
n
转换为
d
进制数输出,并输出
d
进制数中最大位值是多少,在第几位。
d
的取值在
2-32
之间,数制
d
超过
10
时,依次用
ABC...
代表其基本符号,如对
17
进制而言,
G
代表其最大符号,对应十进制的
16
。
提示:用递归函数完成十进制向d进制的转换是需要掌握的,但对于本题而言,由于要在转换后的各位数上进行查找,建议用数组存放转换后的各位数值。右边是运行示例:
#include<iostream>
#include<iomanip>
using namespace std;
void tran(int n, int d);
char a[32]="0123456789ABCDEFGHIJKLMNOPQRSTU";
int main()
{
int n=1000;
tran(n, 8);
tran(n, 24);
tran(n, 2);
return 0;
}
void tran(int n, int d)
{
int c[30];
int i=0;
cout<<n<<"转换为"<<setw(2)<<d<<"进制为: ";
while(n)
{
c[i++]=n%d;
n=n/d;
}
int m=i-1;
for(;i-1>=0;i--)
cout<<a[c[i-1]];
cout<<endl;
int max=c[0];
int num[30];
for(int j=1;j<=m;j++)
if (max<c[j]){max=c[j]; }
cout<<"各位中的最大值是"<<a[max]<<","<<"出现在第";
for(int j=0;j<=m;j++)
if (max==c[j])cout<<" "<<j+1<<" ";
cout<<"位上。。"<<endl;
cout<<endl;
}