poj 1455-Crazy tea Party-类似冒泡排序

     如果所有人是线性排列,那我们的工作就是类似冒泡程序做的工作:1,2,3,4,5变为5,4,3,2,1 ,耗时n(n-1)/2
但是出现了环,也就是说1,2,3,4,5变为3,2,1,5,4也可满足条件  
我们可以把这个环等分成两个部分 ,每个部分看成是线性的,再把它们花的时间加起来.
当n是偶数时, 每份人数n/2 ,即 2*(n/2 )*(n/2 -1)/2;

当n是奇数时,两份的人数分别是n/2和n/2+1,即(n/2)*(n/2 -1)/2 + (n/2 +1)*(n/2)/2


代码:

#include <stdio.h>
#include <math.h>
#include <cstdio>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#include <string>
#include <cstring> 
#include <cmath>
#define setbit(x,y) x|=(1<<(y)) //将X的第Y位置1
#define clrbit(x,y) x&=~(1<<(y)) //将X的第Y位清0
#define sf scanf
#define pf printf
#define INF 1 << 29
#define eps 1e-6
const double PI = acos(-1.0);               
#define lint __int64
#define LL long long 
#define MAX 1e9 + 7
#define maxn 10005
//101^110=011 异或
#define ULLint unsigned long long //2^64-1>1.8*10^19
#define clr(x) memset(x, 0, sizeof(x))
#define Clr(x) memset(x, -1, sizeof(x))

using namespace std;

int main () {
	int i;
	int n;
	int cas;
	cin >> cas;
	while ( cas --) {
		cin >> n;
		if (n == 1) cout << 0 << endl;
		else if (n == 2) cout << 0 << endl;
		else if (n == 3) cout << 1 << endl;
		else {
			if (n & 1) {
				cout << (n / 2) * (n / 2) << endl;
			}
			else {
				cout << (n / 2) * (n / 2 - 1) << endl;
			}
		}
	}
	return 0;
}



你可能感兴趣的:(poj 1455-Crazy tea Party-类似冒泡排序)