亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? report.cpp

?? 股票軟件
?? CPP
字號(hào):
/*
	Cross Platform Core Code.

	Copyright(R) 2001-2002 Balang Software.
	All rights reserved.

	Using:
		class	CReport;
*/

#include	"StdAfx.h"
#include	"Stock.h"

#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

#ifdef	_DEBUG
#define	new	DEBUG_NEW
#endif

/////////////////////////////////////////////////////////////////////////////

CReport::CReport()
{
	m_pData = NULL;
	m_nSize = m_nMaxSize = m_nGrowBy = 0;
}

CReport::CReport( const CReport &src )
{
	m_pData = NULL;
	m_nSize = m_nMaxSize = m_nGrowBy = 0;

	*this	=	src;
}

CReport::~CReport()
{
	if( m_pData )
		delete [] (BYTE*)m_pData;
}

void CReport::SetSize(int nNewSize, int nGrowBy /* = -1 */)
{
	SP_ASSERT(nNewSize >= 0);

	if (nGrowBy != -1)
		m_nGrowBy = nGrowBy;  // set new size

	if (nNewSize == 0)
	{
		// shrink to nothing
		delete [] (BYTE*)m_pData;
		m_pData = NULL;
		m_nSize = m_nMaxSize = 0;
	}
	else if (m_pData == NULL)
	{
		// create one with exact size
#ifdef SIZE_T_MAX
		SP_ASSERT((long)nNewSize * sizeof(REPORT) <= SIZE_T_MAX);  // no overflow
#endif
		m_pData = (REPORT*) new BYTE[nNewSize * sizeof(REPORT)];

		memset(m_pData, 0, nNewSize * sizeof(REPORT));  // zero fill

		m_nSize = m_nMaxSize = nNewSize;
	}
	else if (nNewSize <= m_nMaxSize)
	{
		// it fits
		if (nNewSize > m_nSize)
		{
			// initialize the new elements

			memset(&m_pData[m_nSize], 0, (nNewSize-m_nSize) * sizeof(REPORT));

		}

		m_nSize = nNewSize;
	}
	else
	{
		// Otherwise grow array
		int nNewMax;
		if (nNewSize < m_nMaxSize + m_nGrowBy)
			nNewMax = m_nMaxSize + m_nGrowBy;  // granularity
		else
			nNewMax = nNewSize;  // no slush

#ifdef SIZE_T_MAX
		SP_ASSERT((long)nNewMax * sizeof(REPORT) <= SIZE_T_MAX);  // no overflow
#endif
		REPORT* pNewData = (REPORT*) new BYTE[nNewMax * sizeof(REPORT)];

		// copy new data from old
		memcpy(pNewData, m_pData, m_nSize * sizeof(REPORT));

		// construct remaining elements
		SP_ASSERT(nNewSize > m_nSize);

		memset(&pNewData[m_nSize], 0, (nNewSize-m_nSize) * sizeof(REPORT));


		// get rid of old stuff (note: no destructors called)
		delete [] (BYTE*)m_pData;
		m_pData = pNewData;
		m_nSize = nNewSize;
		m_nMaxSize = nNewMax;
	}
}

void CReport::FreeExtra()
{
	if (m_nSize != m_nMaxSize)
	{
		// shrink to desired size
#ifdef SIZE_T_MAX
		SP_ASSERT((long)m_nSize * sizeof(REPORT) <= SIZE_T_MAX);  // no overflow
#endif
		REPORT* pNewData = NULL;
		if (m_nSize != 0)
		{
			pNewData = (REPORT*) new BYTE[m_nSize * sizeof(REPORT)];
			// copy new data from old
			memcpy(pNewData, m_pData, m_nSize * sizeof(REPORT));
		}

		// get rid of old stuff (note: no destructors called)
		delete [] (BYTE*)m_pData;
		m_pData = pNewData;
		m_nMaxSize = m_nSize;
	}
}

/////////////////////////////////////////////////////////////////////////////

void CReport::SetAtGrow(int nIndex, REPORT newElement)
{
	SP_ASSERT(nIndex >= 0);

	if (nIndex >= m_nSize)
		SetSize(nIndex+1);
	m_pData[nIndex] = newElement;
}

void CReport::InsertAt(int nIndex, REPORT newElement, int nCount /*=1*/)
{
	SP_ASSERT(nIndex >= 0);    // will expand to meet need
	SP_ASSERT(nCount > 0);     // zero or negative size not allowed

	if (nIndex >= m_nSize)
	{
		// adding after the end of the array
		SetSize(nIndex + nCount);  // grow so nIndex is valid
	}
	else
	{
		// inserting in the middle of the array
		int nOldSize = m_nSize;
		SetSize(m_nSize + nCount);  // grow it to new size
		// shift old data up to fill gap
		memmove(&m_pData[nIndex+nCount], &m_pData[nIndex],
			(nOldSize-nIndex) * sizeof(REPORT));

		// re-init slots we copied from

		memset(&m_pData[nIndex], 0, nCount * sizeof(REPORT));

	}

	// insert new value in the gap
	SP_ASSERT(nIndex + nCount <= m_nSize);
	while (nCount--)
		m_pData[nIndex++] = newElement;
}

void CReport::RemoveAt(int nIndex, int nCount /* = 1 */)
{
	SP_ASSERT(nIndex >= 0);
	SP_ASSERT(nCount >= 0);
	SP_ASSERT(nIndex + nCount <= m_nSize);

	// just remove a range
	int nMoveCount = m_nSize - (nIndex + nCount);

	if (nMoveCount)
		memcpy(&m_pData[nIndex], &m_pData[nIndex + nCount],
			nMoveCount * sizeof(REPORT));
	m_nSize -= nCount;
}

void CReport::InsertAt(int nStartIndex, CReport* pNewArray)
{
	SP_ASSERT(pNewArray != NULL);
	SP_ASSERT(nStartIndex >= 0);

	if (pNewArray->GetSize() > 0)
	{
		InsertAt(nStartIndex, pNewArray->GetAt(0), pNewArray->GetSize());
		for (int i = 0; i < pNewArray->GetSize(); i++)
			SetAt(nStartIndex + i, pNewArray->GetAt(i));
	}
}

int CReport::InsertReportSort( REPORT newElement )
{
	if( newElement.m_time <= 0 )
		return -1;
	if( newElement.m_fNew < 1e-4 )
		return -1;
	if( newElement.m_fVolume < 1e-4 )
		return -1;
	if( !CSPTime::InTradeTime( newElement.m_time, 60 ) )
		return -1;

	for( int i=GetSize()-1; i>=0; i-- )
	{
		REPORT & temp = ElementAt(i);
		if( newElement.m_time == temp.m_time )
		{
			SetAt(i,newElement);
			return i;
		}
		if( fabs(newElement.m_fVolume - temp.m_fVolume) < 1e-4 )
		{
			SetAt(i,newElement);
			return i;
		}
		if( newElement.m_time >= temp.m_time && newElement.m_fVolume > temp.m_fVolume )
		{
			InsertAt(i+1,newElement);
			return i+1;
		}
		if( newElement.m_time > temp.m_time && newElement.m_fVolume < temp.m_fVolume )
			return -1;
		if( newElement.m_time < temp.m_time && newElement.m_fVolume > temp.m_fVolume )
			return -1;
	}
	
	InsertAt( 0, newElement );
	return 0;
}

int SortReport(const void *p1,const void *p2)
{
	REPORT *pTemp1 = (REPORT *)p1;
	REPORT *pTemp2 = (REPORT *)p2;

	if( pTemp1 && pTemp2 && pTemp1->m_time < pTemp2->m_time )
		return -1;
	else if( pTemp1 && pTemp2 && pTemp1->m_time > pTemp2->m_time )
		return 1;
	if( pTemp1 && pTemp2 && pTemp1->m_fVolume < pTemp2->m_fVolume )
		return -1;
	else if( pTemp1 && pTemp2 && pTemp1->m_fVolume > pTemp2->m_fVolume )
		return 1;
	return 0;
}

void CReport::Sort( )
{
	if( m_pData )
		qsort( m_pData, GetSize(), sizeof(REPORT), SortReport );
}

void CReport::RemoveDirty( )
{
	for( int i=GetSize()-1; i>=0; i-- )
	{
		if( ElementAt(i).m_time <= 0 )
			RemoveAt(i);
		else if( ElementAt(i).m_fNew < 1e-4 )
			RemoveAt(i);
		else if( ElementAt(i).m_fVolume < 1e-4 )
			RemoveAt(i);
		else if( !CSPTime::InTradeTime( ElementAt(i).m_time, 60 ) )
			RemoveAt(i);
		else if( i>0 && ElementAt(i).m_fVolume - ElementAt(i-1).m_fVolume < 1e-4 )
			RemoveAt(i);
	}
}

CReport	& CReport::operator = ( const CReport &src )
{
	Copy( src );
	return	*this;
}

void CReport::Copy( const CReport &src )
{
	SetSize( 0, src.GetSize()+5 );
	for( int i=0; i<src.GetSize(); i++ )
	{
		Add( src.GetAt(i) );
	}
}

BOOL CReport::GetMMLD( int nIndex, double *pdVolBuy, double *pdVolSell, double * pdVolDiff )
{
	SP_ASSERT( nIndex >= 0 && nIndex < GetSize() );
	if( nIndex < 0 || nIndex > GetSize()-1 )
		return FALSE;

	double	dVolBuy = 0;
	double	dVolSell = 0;
	REPORT & rpt = ElementAt(nIndex);

	int k;

	for(  k=0; k<sizeof(rpt.m_fBuyVolume)/sizeof(rpt.m_fBuyVolume[0]); k++ )
		dVolBuy		+=	rpt.m_fBuyVolume[k];
	for(  k=0; k<sizeof(rpt.m_fSellVolume)/sizeof(rpt.m_fSellVolume[0]); k++ )
		dVolSell	+=	rpt.m_fSellVolume[k];
	
	if( pdVolBuy )	*pdVolBuy	=	dVolBuy;
	if( pdVolSell )	*pdVolSell	=	dVolSell;
	if( pdVolDiff )	*pdVolDiff	=	(dVolBuy-dVolSell);
	return TRUE;
}

BOOL CReport::GetMMLDMinMaxInfo( double *pdMin, double *pdMax )
{
	double	dMin = 0, dMax = 1;
	for( int i=0; i<GetSize(); i++ )
	{
		double	dVolBuy = 0;
		double	dVolSell = 0;
		GetMMLD( i, &dVolBuy, &dVolSell, NULL );

		if( 0 == i )
		{
			dMin	=	dVolBuy;
			dMax	=	dVolBuy;
		}
		if( dVolBuy < dMin )	dMin	=	dVolBuy;
		if( dVolBuy > dMax )	dMax	=	dVolBuy;
		if( dVolSell < dMin )	dMin	=	dVolSell;
		if( dVolSell > dMax )	dMax	=	dVolSell;
	}

	if( dMax < 500 )
		dMax	=	500;	// 最小為5手

	if( pdMin )	*pdMin	=	dMin;
	if( pdMax )	*pdMax	=	dMax;
	return TRUE;
}

BOOL CReport::StatBuySellEx( float * fSellPrice, float * fSellVolume, float * fBuyPrice, float * fBuyVolume, int nSize )
{
	int k=0, i=0;
	for( k=0; k<nSize; k++ )
	{
		fSellPrice[k]	=	0.;
		fSellVolume[k]	=	0.;
		fBuyPrice[k]	=	0.;
		fBuyVolume[k]	=	0.;
	}

	CSPDWordArray	adwSellPrice, adwSellVolume, adwBuyPrice, adwBuyVolume;
	REPORT	rpt;
	memset( &rpt, 0, sizeof(rpt) );
	int	nBSCount	=	sizeof(rpt.m_fBuyPrice)/sizeof(float);

	for( k=0; k<GetSize(); k++ )
	{
		REPORT	& report	=	ElementAt(k);
		
		// Insert
		for( int i=nBSCount-1; i>=0; i-- )
		{
			if( report.m_fSellPrice[i] > 1e-4 )
			{
				adwSellPrice.InsertAt( 0, DWORD(report.m_fSellPrice[i]*1000) );
				adwSellVolume.InsertAt( 0, DWORD(report.m_fSellVolume[i]) );
			}
			if( report.m_fBuyPrice[i] > 1e-4 )
			{
				adwBuyPrice.InsertAt( 0, DWORD(report.m_fBuyPrice[i]*1000) );
				adwBuyVolume.InsertAt( 0, DWORD(report.m_fBuyVolume[i]) );
			}
		}

		// Remove 
		DWORD	dwSellMin = 0;
		for(  i=0; i<adwSellPrice.GetSize(); i++ )
		{
			if( adwSellPrice[i] < dwSellMin+1e-4 )
			{
				adwSellPrice.RemoveAt(i);
				adwSellVolume.RemoveAt(i);
				i --;
			}
			else
			{
				dwSellMin	=	adwSellPrice[i];
			}
		}

		DWORD	dwBuyMax = 0;
		for(  i=0; i<adwBuyPrice.GetSize(); i++ )
		{
			if( 0 != dwBuyMax && adwBuyPrice[i] > dwBuyMax-1e-4 )
			{
				adwBuyPrice.RemoveAt(i);
				adwBuyVolume.RemoveAt(i);
				i --;
			}
			else
			{
				dwBuyMax	=	adwBuyPrice[i];
			}
		}
	}

	// Store
	for( k=0; k<nSize && k<adwSellPrice.GetSize(); k++ )
	{
		fSellPrice[k]	=	float(0.001 * adwSellPrice[k]);
		fSellVolume[k]	=	float(adwSellVolume[k]);
	}
	for( k=0; k<nSize && k<adwBuyPrice.GetSize(); k++ )
	{
		fBuyPrice[k]	=	float(0.001 * adwBuyPrice[k]);
		fBuyVolume[k]	=	float(adwBuyVolume[k]);
	}

	return TRUE;
}

/////////////////////////////////////////////////////////////////////////////



?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国内精品不卡在线| 久久精品国产99久久6| 亚洲妇女屁股眼交7| 国产电影一区在线| 欧美日韩亚洲综合| 国产欧美日本一区视频| 亚洲成av人综合在线观看| 国产在线精品不卡| 在线观看国产91| 国产网红主播福利一区二区| 亚洲不卡一区二区三区| jlzzjlzz欧美大全| 精品国产一区二区国模嫣然| 亚洲一区二区三区视频在线播放| 国产一区二区三区在线观看免费 | 欧美日韩亚洲综合| 中文字幕乱码日本亚洲一区二区| 日产精品久久久久久久性色| 色综合中文综合网| 国产婷婷色一区二区三区 | 中文字幕亚洲精品在线观看| 九色综合狠狠综合久久| 欧美日韩日日摸| 一区二区三区在线播放| 成人免费三级在线| 久久亚洲一区二区三区四区| 蜜臀av性久久久久蜜臀aⅴ| 91成人免费在线视频| 亚洲私人黄色宅男| 成人理论电影网| 欧美国产一区视频在线观看| 国产精品中文字幕日韩精品| 精品对白一区国产伦| 美女mm1313爽爽久久久蜜臀| 欧美一级黄色片| 奇米综合一区二区三区精品视频| 欧美日韩高清一区| 亚洲3atv精品一区二区三区| 欧美日韩免费在线视频| 午夜a成v人精品| 欧美色爱综合网| 丝袜亚洲另类欧美综合| 欧美日韩亚洲另类| 日韩福利电影在线观看| 欧美一级在线免费| 久久99热这里只有精品| 久久久久久久久蜜桃| 大白屁股一区二区视频| 国产精品电影一区二区| 91美女片黄在线观看91美女| 亚洲aaa精品| 欧美大白屁股肥臀xxxxxx| 麻豆精品精品国产自在97香蕉 | 在线精品国精品国产尤物884a| 一区二区三区四区高清精品免费观看| 91麻豆精品在线观看| 亚洲一区二区精品3399| 欧美一区二区视频在线观看2020 | 婷婷综合另类小说色区| 91精品国产综合久久久久久久久久| 日本色综合中文字幕| 久久综合一区二区| 9久草视频在线视频精品| 亚洲一级电影视频| 精品国产乱码久久久久久久久| 国产成人av影院| 一卡二卡欧美日韩| 日韩你懂的在线播放| gogo大胆日本视频一区| 日日夜夜精品视频免费| 国产视频一区在线播放| 欧美中文字幕一区二区三区| 久久国内精品自在自线400部| 国产精品三级av| 欧美日韩精品久久久| 国产成人综合亚洲网站| 亚洲小少妇裸体bbw| 精品国产1区2区3区| 91成人在线精品| 国产精品亚洲一区二区三区在线| 一区二区三区av电影| 精品国产一区二区三区忘忧草| 91热门视频在线观看| 精品亚洲免费视频| 一区二区三区日本| 欧美激情一区二区三区全黄 | 久久精品男人的天堂| 欧美网站大全在线观看| 国产成人av在线影院| 麻豆91在线观看| 一区二区三区免费网站| 久久久久久久久岛国免费| 欧美日韩国产一级片| 91一区二区在线观看| 国产精品一区久久久久| 日日噜噜夜夜狠狠视频欧美人| 成人免费视频在线观看| 国产亚洲一区二区三区| 91精选在线观看| 色综合久久久久久久久久久| 国产成人免费网站| 极品少妇一区二区三区精品视频 | 国产精品538一区二区在线| 亚洲福利视频一区二区| 自拍视频在线观看一区二区| 国产女人水真多18毛片18精品视频| 欧美一区二区三区视频在线| 欧美日韩国产一区| 欧美日韩激情一区| 91黄色在线观看| 91视频在线看| 91亚洲午夜精品久久久久久| 成人激情小说网站| www.99精品| 97久久精品人人做人人爽50路| 粉嫩一区二区三区性色av| 国产麻豆成人精品| 国产一区美女在线| 国产精品一二三四| 国产白丝网站精品污在线入口| 国产99久久久国产精品免费看| 国产不卡在线播放| 91在线免费视频观看| av不卡在线观看| 色噜噜久久综合| 欧美日韩精品欧美日韩精品一 | 在线中文字幕一区| 日本韩国一区二区三区| 欧美日韩大陆一区二区| 欧美精品日韩精品| 日韩欧美国产1| 国产农村妇女毛片精品久久麻豆| 国产无遮挡一区二区三区毛片日本| 国产日韩欧美精品在线| 国产精品久久久爽爽爽麻豆色哟哟 | 亚洲精品免费在线| 亚洲国产欧美一区二区三区丁香婷| 一区二区三区欧美| 另类小说视频一区二区| 国产综合久久久久久鬼色| 国产不卡在线一区| 欧美影院一区二区三区| 日韩女优视频免费观看| 中文字幕免费一区| 亚洲v精品v日韩v欧美v专区| 久久99精品网久久| 成人动漫中文字幕| 欧美视频在线一区| 精品处破学生在线二十三| 国产免费久久精品| 亚洲国产精品麻豆| 国产自产高清不卡| 色哟哟亚洲精品| 欧美一区二区三区免费在线看 | 欧美一区二区三区视频免费| 久久久99久久| 一级日本不卡的影视| 九九精品一区二区| 91麻豆蜜桃一区二区三区| 日韩视频在线你懂得| 亚洲欧洲精品一区二区三区| 婷婷国产在线综合| 不卡的av在线播放| 日韩一级片网站| 最近日韩中文字幕| 久久精品国产久精国产爱| 99久久精品免费看国产| 精品久久久久久久人人人人传媒 | 国产欧美日韩三级| 婷婷久久综合九色综合伊人色| 国产露脸91国语对白| 欧美日韩免费视频| 综合久久久久综合| 国产99久久久国产精品潘金| 91精品国产欧美日韩| 亚洲美女偷拍久久| 国产jizzjizz一区二区| 日韩欧美一级在线播放| 亚洲国产视频一区二区| yourporn久久国产精品| 国产日韩在线不卡| 国内偷窥港台综合视频在线播放| 欧美专区日韩专区| 亚洲日本在线看| 成人精品免费网站| 久久视频一区二区| 免费国产亚洲视频| 欧美男生操女生| 亚洲电影中文字幕在线观看| 99视频精品在线| 中文字幕一区二区三区视频| 国产福利不卡视频| 久久精品人人爽人人爽| 麻豆视频一区二区| 精品久久久网站| 国产最新精品免费| 亚洲精品一区二区三区香蕉| 久久99久久99小草精品免视看| 欧美日韩成人综合在线一区二区 | 国产精品77777|