解题思路:这题就是转换进制,第一个输出要去前导零(为什么我开始没想到!害我调了好久的BUG(QAQ))
第二个输出大家懂得都懂(十六转十)但记得字符转整型时要调整(详细见ASCLL码表)(快一点可以用cmath库的计算次方)
计算次方代码:pow(底数,指数);--->pow(a,b);=a的b次方
第三个输出就十转八(不想写!我要摆烂!)
(开玩笑!我哪有那么爱摆烂!)
可以用像回文数的方法做,(就是取余8后除8,在坐的肯定懂我意思,对8。)
要反向输出!^_^
注意事项: 不要想着看懂我代码(反正你肯定看不懂我代码(^_^))
参考代码:
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
string ss;
int n,i,sum=0,t=0,s=0,s1=0,k=0,a[8005]={};
bool flag=0;
cin>>ss;
for(i=0;i<ss.length();i++)
{
if(flag==0 && ss[i]=='0')
{
}
else if(flag==0 && ss[i]!=0)
{
cout<<ss[i];
flag=1;
k=1;
}
else
{
cout<<ss[i];
k=1;
}
}
if(k==0)
{
cout<<'0';
}
k=0;
cout<<" ";
//十六转十
for(i=0;i<ss.length();i++)
{
if(ss[i]>='A' && ss[i]<='F')
{
n=(int)ss[i];
n=n-55;
}
else if(ss[i]>='0' && ss[i]<='9')
{
n=(int)ss[i];
n=n-48;
}
t=n*pow(16,ss.length()-i-1);
sum=sum+t;
t=0;
}
//十转八
cout<<sum<<" ";
t=0;
s=sum;
sum=0;
if(s==0)
{
cout<<'0';
return 0;
}
while(s>0)
{
sum++;
a[sum]=s%8;
s=s/8;
}
for(i=sum;i>=1;i--)
{
cout<<a[i];
}
return 0;
}
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题8.4 (Java代码)浏览:788 |
Tom数 (C++代码)浏览:868 |
大小写转换 (C语言代码)浏览:904 |
用筛法求之N内的素数。 (C语言代码)浏览:1385 |
WU-链表数据求和操作 (C++代码)浏览:1382 |
杨辉三角 (C语言代码)浏览:505 |
找出最长的字符串来 (C语言代码)浏览:1840 |
C语言程序设计教程(第三版)课后习题8.5 (C语言代码)浏览:581 |
C语言程序设计教程(第三版)课后习题6.5 (C语言代码)浏览:505 |
简单的a+b (C语言代码)浏览:672 |