如何解决使用按位运算符[closed]交换整数中的第一位和最后一位
||解决方法
使用
int digits = log10(x)
获得位数。
用int first = x / pow(10,digits)
获得第一个数字。
用int last = x % 10
取最后一位。
放在一起就可以了
int swapped = x + (last - first) * pow(10,digits) + (first - last)
, 一个简单的解决方案:
def swap_digit(n):
x = str(n)
if len(x) < 2:
return x
return int(x[-1] + x[1:-1] + x[0])
编辑:添加了快速而肮脏的C解决方案
#include <stdio.h>
#include <string.h>
int main()
{
int n = 123456789;
char buf[100];
int r = snprintf(buf,sizeof(buf),\"%d\",n);
char t = buf[0];
buf[0] = buf[r-1];
buf[r-1] = t;
int swap;
sscanf(buf,&swap);
printf(\"n = %d,swap = %d\\n\",n,swap);
return 0;
}
, def swap(i):
s = list(str(i))
s[0],s[-1] = s[-1],s[0]
i = int(\'\'.join(s))
return i
print swap(123456789) # 923456781
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。