关于位与运算 求二进制

今天一朋友发我这个代码 输入一个数 然后输出居然是这个数的二进制
我实在看 不懂 求大神解释下 还有 用这种方法能求n进制吗 求指教

 #include<stdio.h>
#include<stdlib.h>
int main()
{
    unsigned int m,temp=1,i;
    temp=temp<<31;
    scanf("%d",&m);
    for(i=1;i<=32;i++)
    {
        putchar(m&temp?'1':'0');
        m=m<<1;
    }
    putchar('\n');
    return 0;
}

temp=temp<<31; //32位系统上int有32位,这是将整数1移到最高位上,

for(i=1;i<=32;i++)
{
putchar(m&temp?'1':'0');
m=m<<1;
}

    这段代码是将用户输入的整数m最高位与temp求与,前面提到temp最高位是1,即用m的最高位和1求与并输出。然后将m左移1位,更新最高位。以此运行32次,则将结果转换为2进制。

    这个方法不能实现N进制转换