先说明下思路:
此题确实是出给我们的一大难题,为什么这要说呢?楼主要求的是文本内所有超大数值的排序,
所有的数值都远远超过了cmd所能运算的最大数值,用常规的比较法都是行不通的这是难点之一;
第二这些数值是随机生成的且字符总数不定,甚至可能达到数行和数十行之长,如采用逐字符判断
的方法来确实行最大字符数,效率将会是此类方案所无法逾越的障碍;第三楼主要求不生成临时文
件,这对用findstr /o来获取行最大字符的方案来讲,无疑是锁上了大门。
综上所述总结如下:
代码要通用就要获取行最大字符数,一种方法是逐字符法,用逐字符法效率上就存在很大问题;
第二种方法是使用findstr /o一次性获取每行字符偏移量,再通过处理获得行最大字符数,效率上比
逐字符法是高多了,但因为单用findstr /o是不能获得文本行未行字符偏移量的,必须要对未行强加
回车,在不破坏原文件的情况下就要用到临时文件。
而我们写代码时一般遵循四条原则:高效率、通用、简洁、尽量不生成临时文件,其中首要的
一条就是高效,其次是通用,至于简洁和有无临时文件都不是主要考虑因素,所以依此主次关系我
给出以下两种方案:
一、通用性差一点(数值字符都在一行内是绝对没问题的),效率高,代码简洁,无临时文件:- @echo off&setlocal enabledelayedexpansion
- for /l %%i in (1,1,80) do set "kong=!kong!#"
- for /f %%i in (1.txt) do (
- set "str=%%i%kong%"
- set "a=!str:~,80!"
- set "a=!a:%%i=!"
- set "_!a!%%i=a"
- )
- for /f "delims==_" %%i in ('set _') do (
- set "str=%%i"
- echo !str:#=!
- )
- pause>nul
复制代码 当然也能通过修改80的值为更高来提高其通用性。
二、通用性极高,效率一般,生成临时文件,代码较复杂:- @echo off&setlocal enabledelayedexpansion
- set "max=0"&set "a=0"
- for /f %%i in (1.txt) do echo %%i>>2.txt
- echo.>>2.txt
- for /f "tokens=1,2* delims=:" %%i in ('findstr /n /o .* 2.txt') do (
- set /a n+=1,m=n-1
- set "num=%%i"&set "_!n!=%%j"&set "#%%i=%%k"
- if !m! gtr 0 set /a a=_!n!-_!m!-2
- if !max! lss !a! set "max=!a!"
- )
- set /a num-=1
- for /l %%i in (1,1,%max%) do set "kong=!kong!#"
- for /l %%i in (1,1,%num%) do (
- set "str=!#%%i!%kong%"
- set "a=!str:~,%max%!"
- call,set "a=%%a:!#%%i!=%%"
- set ".!a!!#%%i!=a"
- )
- for /f "delims==." %%i in ('set .') do (
- set "str=%%i"
- echo !str:#=!
- )
- del /q 2.txt&pause>nul
复制代码
[ 本帖最后由 batman 于 2008-8-5 21:14 编辑 ] |