奇偶位互换
Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 4509 Accepted Submission(s): 3457
Problem Description
给定一个长度为偶数位的0,1字符串,请编程实现串的奇偶位互换。
Input
输入包含多组测试数据;
输入的第一行是一个整数C,表示有C测试数据;
接下来是C组测试数据,每组数据输入均为0,1字符串,保证串长为偶数位(串长<=50)。
输入的第一行是一个整数C,表示有C测试数据;
接下来是C组测试数据,每组数据输入均为0,1字符串,保证串长为偶数位(串长<=50)。
Output
请为每组测试数据输出奇偶位互换后的结果;
每组输出占一行。
每组输出占一行。
Sample Input
2 0110 1100
Sample Output
1001 1100
Author
yifenfei
基础题。 if (i&1) 用来判断i的奇偶。位运算。如果i为奇数,则结果为1,若为偶数则为0。
#include<stdio.h>
#include<string.h>
int main()
{
char a[100],t;
int c,i;
while(~scanf("%d",&c))
{
while(c--)
{
scanf("%s",a);
for(i=0;i<strlen(a);i++)
{
if(i&1)
{
t=a[i];
a[i]=a[i-1];
a[i-1]=t;
}
}
printf("%s\n",a);
}
}
return 0;
}