zoukankan      html  css  js  c++  java
  • [手游项目2]-12-min 到max随机n个不同的数

    #include <Windows.h>
    #include <vector>
    
    int Rand(int from,int to)
    {
    	int  nDec, nMin;
    
    	if (from > to)
    	{
    		nDec =  from - to + 1;
    		nMin = to;
    	}
    	else
    	{
    		nDec =  to - from + 1;
    		nMin = from;
    	}
    
    	int nRand = rand() % nDec + nMin;
    
    	return nRand;
    }
    
    //数组下标减掉min是为了减少tabTemp初始化的大小,节约内存,
    void MultRandom(std::vector<int>&tabRet, int nMin, int nMax, int nRandCount )
    {
    	int nTemp = nMax - nMin + 1;
    	if (nTemp < nRandCount ||  nRandCount <= 0)
    	{
    		return ;
    	}
    	tabRet.clear();
    	std::vector<int>tabTemp(nTemp, nMax + 1);
    	int nTop = nMax;
    	for (int i = 1; i<= nRandCount; i++)
    	{
    		int nRandResult = Rand(nMin, nTop);
    		int nResult = 0;
    		if(tabTemp[nRandResult - nMin] <= nMax && nMin <= tabTemp[nRandResult - nMin])
    		{
    			nResult = tabTemp[nRandResult - nMin];
    		}
    		else
    		{
    			nResult = nRandResult;
    		}
    		tabRet.push_back(nResult);
    		if (nRandResult != nTop )
    		{
    			if(tabTemp[nTop - nMin] <= nMax && nMin <= tabTemp[nTop - nMin])
    			{
    				tabTemp[nRandResult - nMin] = tabTemp[nTop - nMin];
    			}
    			else
    			{
    				tabTemp[nRandResult - nMin] = nTop;
    			}
    		}
    		nTop--;
    	}
    }
    
    
    int main()
    {
    	std::vector<int>tabRet;a
    	MultRandom(tabRet,1,100,100);
    	system("pause");
    }
    
  • 相关阅读:
    使用Silverlight 实现工作流流程定义
    中国国内航线信息的可视化
    笨办法学R编程(5)
    笨办法学R编程(4)
    笨办法学R编程(3)
    香山杯部分WP
    PWNABLE 3x17
    PWNABLE dubblesort
    PWNABLE applestore
    pyc文件修复出题经历
  • 原文地址:https://www.cnblogs.com/byfei/p/14104228.html
Copyright © 2011-2022 走看看