// TestRandomGC.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <vector>
#include <algorithm>
#include <iostream>
#include <ctime>
#include <stdio.h>
#include <string>
using namespace std;
/* 已知跑了20个小时后,垃圾量的分布情况,20%垃圾量的档位有22%,22%-50%垃圾量的比较平均了都是5%左右,52的%垃圾量有1%
我们要实现一个可以配置的表(垃圾量分布图),配置不同垃圾量的占比是多少。我们就按照这个表,去随机生成这种垃圾量占比。*/
unsigned int randArrays[100] = {20, 20, 20, 20, 20, 20, 20, 20, 20, 20,
20, 20, 20, 20, 20, 20, 20, 20, 20, 20,
20, 20, 22, 22, 22, 22, 24, 24, 24, 24,
26, 26, 26, 26, 28, 28, 28, 28, 28, 30,
30, 30, 30, 30, 32, 32, 32, 32, 32, 34,
34, 34, 34, 34, 36, 36, 36, 36, 36, 38,
38, 38, 38, 38, 40, 40, 40, 40, 40, 42,
42, 42, 42, 42, 42, 44, 44, 44, 44, 44,
44, 46, 46, 46, 46, 46, 46, 48, 48, 48,
48, 48, 48, 48, 48, 50, 50, 50, 50, 52};
void initVector(vector<unsigned int> &vec, unsigned int size)
{
srand(unsigned(time(NULL)));
for(unsigned int i =0; i < size; i++)
{
int randNum = rand()%100;/* 0-99的随机数作为垃圾量分布图的下标*/
vec.push_back(randArrays[randNum]);
}
}
void printVector(vector<unsigned int> vec)
{
vector<unsigned int>::iterator it = vec.begin();
for(; it != vec.end();++it)
{
printf("%d,", *it);
}
cout<<endl;
}
int _tmain(int argc, _TCHAR* argv[])
{
vector<unsigned int> vect;
initVector(vect, 100);
cout<<"before sort"<<endl;
printVector(vect);
sort(vect.begin(), vect.end());
cout<<"after sort"<<endl;
printVector(vect);
return 0;
}