huangguanyi1225


私信TA

用户名:huangguanyi1225

访问量:243

签 名:

等  级
排  名 10939
经  验 1059
参赛次数 6
文章发表 2
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

解题思路:这题就是转换进制,第一个输出要去前导零(为什么我开始没想到!害我调了好久的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 人评分

  评论区

  • «
  • »