PTA2币值转换

1,代码:

#include<stdio.h>

#include<math.h>
int n,s=0;
int main(void){
 int i,j,k,p=1,flag=1;
 int f(int q,int n);
 scanf("%d",&n);
 
 for(i=0;n/p>=10;i++){
  p=pow(10,i);
  s++;
 }
 if(n==0)
   printf("a");
 if(n<10&&n>=0)
  s=1;
 for(j=1;j<=s;j++){
  switch(f(j,n)){
   case 0:if(j!=s&&j!=s-4){
    if(f(j+1,n)==0)
       flag=0;
    else
       flag=1;
    if(flag)printf("a");break;
    };break;
   case 1:printf("b");break;
   case 2:printf("c");break;
   case 3:printf("d");break;
   case 4:printf("e");break;
   case 5:printf("f");break;
   case 6:printf("g");break;
   case 7:printf("h");break;
   case 8:printf("i");break;
   case 9:printf("j");break;
  }
  if(f(j,n)==0&&j!=s&&j!=s-4)
    continue;
  else{
   if(s==9&&j==5){
    if(f(2,n)==0&&f(3,n)==0&&f(4,n)==0&&f(5,n)==0)
    continue;
   }
  switch(s-j){
   case 1:printf("S");break;
   case 2:printf("B");break;
   case 3:printf("Q");break;
   case 4:printf("W");break;
   case 5:printf("S");break;
   case 6:printf("B");break;
   case 7:printf("Q");break;
   case 8:printf("Y");break;
  }
 }}
 return 0;
}
int f(int q,int n)
{
 int k,a;
 if(q==1)
    k=n/pow(10,s-1);
 else{
  a=n/pow(10,s-q+1);
  k=n/pow(10,s-q)-a*10;
 }
 return k;
}

2,遇到的问题及解决方案:

一开始对题目不是很理解

找IT大佬,翻书,百度

 

转载于:https://www.cnblogs.com/wyh1314520/p/10495590.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值