2023年NOC大赛Python初中组决赛真题-二进制回文
编程实现:输入一个正整数,判断它的二进制形式是否是回文数,如果是输出True,不是输出False例:数字3的二进制形式是11,是一个回文数,输出True。
输入描述
输入一个正整数n。
输出描述
判断数字n的二进制形式是否是回文数,如果是输出True,不是输出False。
输入样例
3
输出样例
True
要点:
1、十进制转二进制
Python内置函数bin()可以将十进制整数转换为二进制数。它返回一个以"0b"开头的二进制字符串,所以结果要去掉‘ob’。
2、判断回文(二选一即可)
方法1:从二进制字符串的两端向中间取数进行比较,如果发现不相等则不是回文。
方法2:reversed()函数对字符串反转迭代,用"".join()连接为字符串,与原始字符串进行对比,检查字符串是否是回文。
参考答案:
#输入一个整数 n = int(input()) #转为二进制字符串ob开头,截取二进制 bin_n = bin(n)[2:] print(bin_n) #方法1:判断是不是回文 i = 0 j = len(bin_n) - 1 res = 'Ture' while i < j: if bin_n[i] != bin_n[j]: res = 'False' i += 1 j -= 1 print(res) #方法2:判断回文 if bin_n=="".join(reversed(bin_n)): print("Ture") else: print("False")
本站内容未经许可,禁止任何网站及个人进行转载。