描述: 根据输入一个字符串整数,通过转换为2进制后,从低到高,当比特为1时,以此比特所在二进制的位置作为索引,
在指定的字符串得到相应字符并输出
如果索引大于字符串的长度小于,则不输出任何字符
输入: 输入字符串整数:13
指定字符串:abcd
输出: 由于13对应的二进制码为1101,从右到左数比特为1的索引分别为0,2,3,那对应输出的字符应为a,c,d
因此输入13时,对应的输出应为: acd
样例输入: 13 abcd
样例输出: acd
代码如下:
#include
#include
#include
#define M 1000
void main()
{
char data[M];
char string[M],temp1[M];
int length2,length3,i;
int temp;
char *p;
scanf("%s",data);
scanf("%s",string);
length2 = strlen(string);
temp = atoi(data);
itoa(temp,temp1,2);
length3 = strlen(temp1);
if(length2 >= length3)
{
p = temp1 + length3 -1;
for(i = 0; i < length3;i++)
{
if(*(p - i) == '1')
{
printf("%c",string[i]);
}
}
}
}