中国DOS联盟

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

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

中国DOS联盟论坛
现在时间是 2026-06-16 01:43
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » [原创]**********起泡排序*********** 查看 909 回复 7
楼 主 [原创]**********起泡排序*********** 发表于 2007-09-15 20:55 ·  中国 北京 鹏博士BGP
银牌会员
★★★
积分 2,098
发帖 566
注册 2007-09-11 07:27
UID 97070
性别 男
状态 离线
@echo off
setlocal enabledelayedexpansion

:::::::::::::::::::::::::::::::::::::::::Bubble 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 i=1
:q
set changed=False
set /a j=%nx%
:v
set /a k=%j%-1
if !n%k%! gtr !n%j%! (
set /a temporary=!n%k%!
set /a n%k%=!n%j%!
set /a n%j%=!temporary!
set changed=True
)
set /a j-=1
if %j% geq %i% (
if not %j% equ 1 (
goto :v
)
)
if %changed% equ False goto :p
set /a i+=1
if %i% lss %nx% goto :q
::::::::Deal With Numbers::::::::

::::::::Print The Result::::::::
:p
::set /a qi=%maxinc%+1
::set /a zhi=%nx%+%maxinc%
for /l %%c in (1,1,%nx%) 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
2 发表于 2007-09-16 19:40 ·  中国 陕西 西安 电信
初级用户
积分 106
发帖 44
注册 2007-06-01 22:25
UID 90001
性别 男
状态 离线
楼主,能不能给出详细点的解释啊?
3 发表于 2007-09-16 19:58 ·  中国 北京 电信
银牌会员
★★★
积分 2,098
发帖 566
注册 2007-09-11 07:27
UID 97070
性别 男
状态 离线
Originally posted by 1112yuhua at 2007-9-16 07:40 PM:
楼主,能不能给出详细点的解释啊?







起泡排序,就是每次扫描数组时把最轻的"气泡"(最小的数)浮上去,下次扫描时就在本次扫描的数的个数的基础上减少一个,即排除已扫描到的轻"气泡".达到轻在上,重在下的目的.算法是一边扫描,一边交换"气泡"的位置.
4 发表于 2007-09-16 23:10 ·  中国 福建 厦门 电信
初级用户
积分 97
发帖 45
注册 2007-01-31 06:02
UID 78190
性别 男
状态 离线
书上是叫冒泡排序法
5 发表于 2007-09-17 12:14 ·  中国 北京 电信
银牌会员
★★★
积分 2,098
发帖 566
注册 2007-09-11 07:27
UID 97070
性别 男
状态 离线
Originally posted by csx163 at 2007-9-16 11:10 PM:
书上是叫冒泡排序法



有的书上就叫起泡排序.
6 发表于 2007-09-17 13:18 ·  中国 江苏 无锡 电信
初级用户
积分 92
发帖 42
注册 2007-08-14 09:14
UID 95100
性别 男
来自 重庆市巫山县
状态 离线
斑竹难道禁止我发言了?
拾人牙慧者!
7 发表于 2007-09-17 13:21 ·  中国 辽宁 阜新 联通
新手上路
积分 10
发帖 4
注册 2007-08-06 12:46
UID 94725
性别 男
状态 离线
有意思,不错,学习了.................
8 发表于 2007-09-26 16:28 ·  中国 辽宁 本溪 联通
银牌会员
★★★
积分 1,212
发帖 464
注册 2006-12-13 21:11
UID 73417
性别 男
状态 离线
试着写了一个...

@echo off
setlocal enabledelayedexpansion
echo 请输入要排序的数(用逗号分开):
set /p s=
set h=0
for %%i in (!s!) do (
set /a h+=1
set n!h!=%%i
)
for /l %%a in (1,1,!h!) do (
call :label n%%a
)

for /l %%b in (1,1,!h!) do (
set /p=!n%%b! <nul
)
pause>nul
goto :eof

:label
for /l %%j in (1,1,!h!) do (
if !%1! gtr !n%%j! (
set m=!%1!
set %1=!n%%j!
set n%%j=!m!
)
)
goto :eof


VBS版的

n=inputbox("请输入你要排序的数(用逗号分开):","提示","1,32,43,543,264,432,34,764,342,76543,54")
s=split(n,","):l=ubound(s):redim m(l)
for i=0 to l
for j=i to l
if ccur(s(i))<ccur(s(j)) then tmp=s(i):s(i)=s(j):s(j)=tmp
next
m(i)=s(i)
next
msgbox join(m,",")
论坛跳转: