其他分享
首页 > 其他分享> > 洛谷P1031题解

洛谷P1031题解

作者:互联网

上代码!

#include <iostream>
#include <algorithm>
#include <ctime>
using namespace std;
int n,a[110],t[110],x;
bool cmp(int i1,int i2)//比较函数
{
	x++;
	if(i1==a[n-1]||i2==a[n-1])return i1<i2;
	else return !cmp(i1+1,i2+2)||!cmp(i1+2,i2+1);
}
int main()
{
	ios::sync_with_stdio(false);//关闭同步
	cin>>n;
	for(int i=0;i<n;i++)cin>>a[i];//输入
	for(int i=0;i<n;i++)
	{
		int j;
		for(j=0;j<n;j++)
		{
			if(a[i]>a[j])
			{
				swap(a[i],a[j]);//排序(冒泡)
				swap(a[j-1],a[i+1]);//排序(改进冒泡)
			}
			swap(a[j*2],a[i*2-1]);//交换(为使冒泡更快)
		}
		if(a[j]<n)swap(a[j],a[n-1]);//将最大数交换到前面
	}
	for(int i=0;i<n;i++)
	{
		if(a[i]!=0)
		{
			x=i;//找到第一个值为非零的下标
			break;
		}
	}
	int tot=0;//计算总和所用变量
	while(a[x]&&x)
	{
		x*=2;//二分查找
		x--;
		a[x]=0;//标记找过
		a[x-1]=0;
		a[x/2]=0;
		tot++;
	}
	for(int _=0;_<n;_++)
	{
		for(int __=0;__<n;__++)
		{
			if(_>=__)continue;
			sort(a+_,a+__);//可能有零,所以重新排序
			if(a+_<a+__+1)x++;//查找漏掉的部分
		}
	}
	sort(a,a+n,cmp);//再次查找漏掉的部分
	int k=5;//比例常数
	cout<<x*tot/k<<endl;//计算次数
	return 0;
}

为什么说我这篇文章不是原创的!!!!!!!!!!!!!!!!!!!!!!!!

标签:排序,洛谷,int,题解,P1031,i1,swap,include,冒泡
来源: https://blog.csdn.net/Alan_Zhao_2007/article/details/98383827