有2n字符挨个排成一排,前n个是'1',后n个是'0'.如 11110000(此时2n=8),现在交换字符的位置,使之按照 10101010 的模式排列。而且要使字符移动的次数最少,编程计算最少的移动次数。

#include<stdio.h>0
int main()
{
    int n,t;
    scanf("%d",&t);
    for(int i=0;i<t;i++)
    {
        scanf("%d",&n);
         printf("%d\n",n/2);
    }
    return 0;
}

对于2N个字符的最少次数调动排列只需要对前N个进行选择性对调,所以对调次数其实是N的一半;

相关文章:

  • 2022-12-23
  • 2021-06-19
  • 2021-08-22
  • 2021-07-03
  • 2022-02-26
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-12-28
  • 2021-11-11
  • 2021-12-05
  • 2021-07-01
  • 2022-12-23
相关资源
相似解决方案