
2条回答 默认 最新
技术专家团-Joel 2021-10-26 17:07关注你好同学,这道题细看还是跟16进制不太一样,所以考虑的问题还蛮多。
因为输入n=16的时候不是对应于两位16进制即'10',而是对应于一位即'P',所以这个要单独考虑的。下面给个代码供参考:clc;clear n = 10000; letter = 'A':'P'; str = []; while(n~=0) s = mod(n,16); if(s==0)%如果能被16整除,说明这一位肯定是P str = ['P', str]; n = n - 16;%把16减去剩下的继续计算位次 else str = [letter(s), str];%如果不能被16整除那么选择相应的位次比如余数s是1那么选取A,s是2那么选取B end n = floor(n/16);%每次除以16取整 end str %str即为所需结果例子(1)
把第二行改成n=16,结果:str = 'P'例子(2)
把第二行改成n=17,结果:str = 'AA'例子(3)
把第二行改成n=18,结果:str = 'AB'例子(4)
把第二行改成n=33,结果:str = 'BA'例子(5)
把第二行改成n=4000,结果:str = 'OIP'例子(6)
把第二行改成n=10000,结果:str = 'BFPP'可见
4000表示为OIP,而10000表示为BFPP。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报