中国DOS联盟论坛

中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net  论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

游客:  注册 | 登录 | 命令行 | 会员 | 搜索 | 上传 | 帮助 »
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » [原创]**********希尔排序************
作者:
标题: [原创]**********希尔排序************ 上一主题 | 下一主题
s11ss
银牌会员





积分 2098
发帖 566
注册 2007-9-11
状态 离线
『楼 主』:  [原创]**********希尔排序************

@echo off
setlocal enabledelayedexpansion
:::::::::::::::::::::::::::::::::::::::::Shell Sort:::::::::::::::::::::::::::::::::::::::::


::::::::Get Original Numbers::::::::
echo Please input some numbers separated from "," , like 2007,9,14,88:
set /a s=0
set /p str=
set /a len=0
set /a nx=0
:c
call set word=%%str:~%len%,1%%
set /a len+=1
if "%word%" equ "," (set /a nx+=1 & call :e)
if not "%word%" equ "" (goto :c)
set /a nx+=1
call :e
goto :o
:e
set /a sn=%len%-%s%-1
call set n%nx%=%%str:~%s%,%sn%%%
set /a s=%len%
goto :eof
::::::::Get Original Numbers::::::::

::::::::Deal With Numbers::::::::
:o
set /a maxinc=(%nx%-1)/2
set /a num=%nx%+1+%maxinc%
for /l %%a in (%nx%,-1,1) do (set /a kk=%maxinc%+%%a & set /a n!kk!=!n%%a!)
for /l %%b in (1,1,%maxinc%) do (
(set /a n%%b=-214748320)
)
set /a var=1
:n
if %var% equ 1 (set /a m%var%=%maxinc%) else (set /a var2=%var%-1 & call :x)
set /a i=!m%var%!+%maxinc%+1
if !m%var%! equ 0 (goto :p) else (goto :m)
:x
set /a m%var%=!m%var2%!/2
goto :eof
:m
set /a temporary=!n%i%!
set /a j=%i%-!m%var%!
:j
if %temporary% lss !n%j%! (goto :ch)
goto :z
:ch
set /a k=%j%+!m%var%!
set /a n%k%=!n%j%!
set /a j-=!m%var%!
goto :j
:z
set /a k=%j%+!m%var%!
set /a n%k%=%temporary%
set /a i+=1
if %i% lss %num% (goto :m) else (set /a var+=1 & goto :n)
::::::::Deal With Numbers::::::::

::::::::Print The Result::::::::
:p
set /a qi=%maxinc%+1
set /a zhi=%nx%+%maxinc%
for /l %%c in (%qi%,1,%zhi%) do (set str2=!str2!!n%%c! )
echo.
echo The numbers after sorting are:
echo !str2!
echo.
echo Press Any Key To Exit...
pause>nul
goto :eof
::::::::Print The Result::::::::


::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::s11ss
::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::2007-9-15

2007-9-15 14:13
查看资料  发短消息 网志   编辑帖子  回复  引用回复
wudixin96
银牌会员





积分 1928
发帖 931
注册 2007-1-6
状态 离线
『第 2 楼』:  

唯一的建议,不要把全部都左对齐,该缩进就   缩进。

你这样让人看了头痛,不想 往下看了

2007-9-15 16:00
查看资料  发短消息 网志   编辑帖子  回复  引用回复
s11ss
银牌会员





积分 2098
发帖 566
注册 2007-9-11
状态 离线
『第 3 楼』:  

不知道有没有相关的平台来帮我完成这个自动缩进排版的问题?我用的就是记事本.

2007-9-15 16:05
查看资料  发短消息 网志   编辑帖子  回复  引用回复
knoppix7
银牌会员





积分 1287
发帖 634
注册 2007-5-2
来自 cmd.exe
状态 离线
『第 4 楼』:  

没有,要是有我早用了.

2007-9-15 17:08
查看资料  发短消息 网志   编辑帖子  回复  引用回复
slore
铂金会员





积分 5212
发帖 2478
注册 2007-2-8
状态 离线
『第 5 楼』:  

你的语句貌似就:
(set /a n%%b=-214748320)
要缩进而已……

2007-9-15 17:59
查看资料  发短消息 网志   编辑帖子  回复  引用回复
s11ss
银牌会员





积分 2098
发帖 566
注册 2007-9-11
状态 离线
『第 6 楼』:  

en.

2007-9-15 20:49
查看资料  发短消息 网志   编辑帖子  回复  引用回复

请注意:您目前尚未注册或登录,请您注册登录以使用论坛的各项功能,例如发表和回复帖子等。


可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题



论坛跳转: