信息发布软件,b2b软件,广告发布软件

 找回密码
 立即注册
搜索

vb.net排序文件名算法和实例操作教程

查看数: 3543 | 评论数: 2 | 收藏 0
关灯 | 提示:支持键盘翻页<-左 右->
    组图打开中,请稍候......
发布时间: 2016-11-19 16:23

正文摘要:

VB.NET编程语言的应用,帮助开发人员在一定程度上提高了程序开发效率。而且其应用范围比较广泛,使用技巧多样化。比如在对文件的操作上就能够体会到它的功能强大性。首先让我们一起来了解一下VB.NET文件名排序的 ...

回复

宣传工具 发表于 2016-11-19 16:24:22
文件多了我们找起来会很困难,我们现在来做一个关于VB.NET文件名排序的一个小案例,以后你的文件都会按一定的顺序排列,也加快你的查询速度。
VB.NET文件名排序案例:
输入 : a1,a2,a10,a001 。我们知道,如果按照字符串比较,结果应该是 a001,a1,a10,a2,但我们期望的结果应该是a001,a1,a2,a10.
自己写了一个VB.NET文件名排序算法,请参考,或者有更好的算法,请赐教
  • VB.NET code /*  
  • Return Value Description  
  • < 0  arg1 less than arg2  
  • 0  arg1 equivalent to arg2  
  • > 0  arg1 greater than arg2  
  • */  
  • int compare(const void* arg1,const void* arg2)  
  • {  
  • if (NULL==arg1||NULL==arg2)//address of item  
  • return 0;  
  • LPSTR lpText1 = *( TCHAR** )arg1; //content of item  
  • LPSTR lpText2 = *( TCHAR** )arg2; //content of item  
  • if (NULL==lpText1||NULL==lpText2)  
  • return 0;  
  • int nText1Len = _tcslen(lpText1);  
  • int nText2Len = _tcslen(lpText2);  
  • int nText1IndexHandled = 0;  
  • int nText2IndexHandled = 0;  
  • int nRet = 0;  
  • for (;;)  
  • {  
  • if (nText1IndexHandled==nText1Len||nText2IndexHandled==nText2Len) //don't compare complete since all are same, "ab","abc"  
  • {  
  • TCHAR chOffset1 = nText1IndexHandled<nText1Len?lpText1[nText1IndexHandled]:0;  
  • TCHAR chOffset2 = nText2IndexHandled<nText2Len?lpText2[nText2IndexHandled]:0;  
  • nRet = (int)((WORD)chOffset1-(WORD)chOffset2);  
  • break;  
  • }  
  • TCHAR ch1 = *(lpText1+nText1IndexHandled);  
  • TCHAR ch2 = *(lpText2+nText2IndexHandled);  
  • if (isdigit(ch1)&&isdigit(ch2)) // if digit, change to number and compare  
  • {  
  • TCHAR* lpNum1 = new TCHAR[nText1Len];  
  • TCHAR* lpNum2 = new TCHAR[nText2Len];  
  • if (NULL==lpNum1||NULL==lpNum2)  
  • return 0;  
  • memset(lpNum1,0,nText1Len*sizeof(TCHAR));  
  • memset(lpNum2,0,nText2Len*sizeof(TCHAR));  
  • extractnumber(lpText1,nText1Len,nText1IndexHandled,lpNum1);  
  • extractnumber(lpText2,nText2Len,nText2IndexHandled,lpNum2);  
  • nRet = comparenumber(lpNum1,lpNum2);  
  • delete[] lpNum1;  
  • delete[] lpNum2;  
  • }  
  • else  
  • {  
  • nRet = (int)((WORD)ch1-(WORD)ch2);  
  • nText1IndexHandled++;  
  • nText2IndexHandled++;  
  • }  
  • if (nRet!=0)  
  • break;  
  • }  
  • return nRet;  
  • }  
  • TCHAR* extractnumber(TCHAR* lpBuf,int nLen,int& nIndexBegin,TCHAR* lpNumber)  
  • {  
  • if (NULL==lpBuf||NULL==lpNumber)  
  • return lpNumber;  
  • for (int i=nIndexBegin,nIndex=0;i<nLen;++i,++nIndexBegin)  
  • {  
  • TCHAR ch = *(lpBuf+i);  
  • if (!isdigit(ch))  
  • break;  
  • lpNumber[nIndex++]=ch;  
  • }  
  • return lpNumber;  
  • }  
  • int comparenumber(TCHAR* lpNumber1,TCHAR* lpNumber2)  
  • {  
  • if (NULL==lpNumber1||NULL==lpNumber2)  
  • return 0;  
  • int nNum1Len = _tcslen(lpNumber1);  
  • int nNum2Len = _tcslen(lpNumber2);  
  • int nMaxLen = max(nNum1Len,nNum2Len);  
  • TCHAR* lpFormatNum1 = new TCHAR[nMaxLen+1];  
  • TCHAR* lpFormatNum2 = new TCHAR[nMaxLen+1];  
  • if (NULL==lpFormatNum1||NULL==lpFormatNum2)  
  • return 0;  
  • memset(lpFormatNum1,_T('0'),nMaxLen*sizeof(TCHAR));  
  • memset(lpFormatNum2,_T('0'),nMaxLen*sizeof(TCHAR));  
  • lpFormatNum1[nMaxLen]=0;  
  • lpFormatNum2[nMaxLen]=0;  
  • int nPos = 0, nRet = 0;  
  • int nIndex = nMaxLen-1;  
  • for (nPos=nNum1Len-1;nPos>=0;--nPos)  
  • lpFormatNum1[nIndex--]=lpNumber1[nPos];  
  • nIndex = nMaxLen-1;  
  • for (nPos=nNum2Len-1;nPos>=0;--nPos)  
  • lpFormatNum2[nIndex--]=lpNumber2[nPos];  
  • for (nPos=0;nPos<nMaxLen;++nPos)  
  • {  
  • nRet = lpFormatNum1[nPos]-lpFormatNum2[nPos];  
  • if (nRet!=0)  
  • break;  
  • }  
  • delete[] lpFormatNum1;  
  • delete[] lpFormatNum2;  
  • return nRet;  
  • }

QQ|( 京ICP备09078825号 )

本网站信息发布软件,是可以发布论坛,发送信息到各大博客,各大b2b软件自动发布,好不夸张的说:只要手工能发在电脑打开IE能发的网站,用这个宣传软件就可以仿制动作,进行推送发到您想发送的B2B网站或是信息发布平台上,不管是后台,还是前台,都可以进行最方便的广告发布,这个广告发布软件,可以按月购买,还可以试用软件,对网站的验证码也可以完全自动对信息发布,让客户自动找上门,使企业轻松实现b2b发布,这个信息发布软件,均是本站原创正版开发,拥有正版的血统,想要新功能,欢迎提意见给我,一好的分类信息群发软件在手,舍我其谁。QQ896757558

GMT+8, 2024-5-8 05:32 , Processed in 0.155438 second(s), 43 queries .

宣传软件--信息发布软件--b2b软件广告发布软件

快速回复 返回顶部 返回列表