活动选择问题的实现(动态规划 和 贪心) (三)

2014-11-24 00:33:26 · 作者: · 浏览: 13
aseDa=inputData[startLoc+n-1].VbyW;//获取基元
goods tmp;
int k=0;
while(j<=startLoc+n-1)
{
if(inputData[j].VbyW>inputData[startLoc+n-1].VbyW||j==startLoc+n-1)
{
i++;
k++;
//交换
tmp=inputData[j];
inputData[j]=inputData[i];
inputData[i]=tmp;

}
j++;
}
startLoc=i-k+1;//左边分组的位置,右边分组的位置为:i+1
fastSort(inputData,i-startLoc,startLoc);
fastSort(inputData,n-(i-startLoc)-1,i+1);


}

测试:

\