[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

【练习-014】出给新手的数值排序加分题

出题目的:
        掌握任意数列之间的排序技巧
解题要求:
        代码通用、高效
        尽量简洁
        尽量不生成临时文件
加分规则:
        1 思路独特基准分5分
        2 代码高效、通用基准分4分
        3 技巧高超基准分3分
        4 代码简洁基准分2分
        5 完美代码加分15分
题目如下:
        给出任意一组数列,正序输出,如:
        3 2008 11 19 777 23 2014 453 789 51
        输出为:3 11 19 23 51 453 777 789 2008 2014
说明:
        不必考虑特大数,所给的数列中都是整数值。
心绪平和,眼藏静谧。

回复 7# terse


    那个set .是什么意思?

TOP

居然才是新手的题目,哎,看来。。。

TOP

哈哈
看到这篇贴子
我知道了有一个叫冒泡排序的东西
另外Batcher兄在另外一个贴子里面给了一个学习冒泡排序的连接
让我好好的学习了一把
我现在把它帮到这里来
希望不懂什么叫冒泡排序的朋友也去学习下
http://www.google.cn/search?hl=z ... %E5%BA%8F&meta=

TOP

有些地方正好对我工作有点用处。

[ 本帖最后由 itrui 于 2008-8-23 21:03 编辑 ]

TOP

原帖由 523066680 于 2008-8-22 14:40 发表
以上部分代码考虑了相同的数 有的没有考虑 。有相同的数 只显示了一次。
(嘿!!!!凭什么我写那个跟你想的¥!@#%@##~!#        就只加我2分啊)

这倒是的~~呵呵~~~
o(∩_∩)o...~~~
空间:http://hi.baidu.com/fair_jm
喜欢批处理的没事的话去逛逛哦~~

TOP

居然没人理我也……17楼的思路是可以完善到 存在重复的数的,
(呜呜 我读书的时候想过这个思路的 估计false也不会考虑给我加分了)
以下是17楼思路的更新版本  允许存在相同的数
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. set hang=3 2008 11 19 777 23 2014 453 789 51 3 3 4 2014
  4. set n=0
  5. for %%a in (%hang%) do (
  6.   set /a num=1,n+=1
  7.   for %%b in (%hang%) do (
  8.     if %%a gtr %%b set /a num+=1
  9.   )
  10. call :next !num!
  11. set !num!=%%a
  12. )
  13. for /l %%a in (1,1,%n%) do echo !%%a!
  14. pause
  15. goto :eof
  16. :next
  17. if defined %num% (set /a num+=1 &goto :next)
复制代码

[ 本帖最后由 523066680 于 2008-8-23 11:37 编辑 ]
2

评分人数

TOP

只需把9楼的代码稍作调整即可。
  1. @echo off
  2. setlocal EnableDelayedExpansion
  3. for /l %%a in (1 1 10) do set "var=!var!!random! "
  4. echo %var%%
  5. for %%i in (%var%) do (
  6. set "str=   %%i"
  7. set "echo=!echo!echo !str:~-5!&"
  8. )
  9. (%echo:~,-1%)|sort
  10. pause>nul
复制代码

[ 本帖最后由 pusofalse 于 2008-8-22 15:03 编辑 ]
心绪平和,眼藏静谧。

TOP

以上部分代码考虑了相同的数 有的没有考虑 。有相同的数 只显示了一次。
(嘿!!!!凭什么我写那个跟你想的¥!@#%@##~!#        就只加我2分啊)

[ 本帖最后由 523066680 于 2008-8-23 11:41 编辑 ]

TOP

原帖由 mkl 于 2008-8-22 09:04 发表
不知是否符合题意@echo off&setlocal enabledelayedexpansion
set "p=3 2008 11 19 777 23 2014 453 789 51"
for %%i in (%p%) do (
   set t=1
   for %%r in (%p%) do (
       if %%i gtr %%r set /a t=!t!+ ...

修改成如下可使代码通用些:
  1. @echo off&setlocal enabledelayedexpansion
  2. set "p=3 2008 11 19 777 23 2014 453 789 51"
  3. for %%i in (%p%) do (
  4.    set /a n+=1,t=1
  5.    for %%r in (%p%) do (
  6.        if %%i gtr %%r set /a t+=1
  7.    )
  8.    set !t!=%%i
  9. )
  10. for /l %%i in (1,1,%n%) do set /p=!%%i! <nul
  11. pause>nul
复制代码

[ 本帖最后由 batman 于 2008-8-22 10:51 编辑 ]
***共同提高***

TOP

好了
根据版主所说改进了一下
还是用了临时文件 不改了 ~~ ~  通用性增强 最大到10位~~
  1. @echo off
  2. setlocal EnableDelayedExpansion
  3. echo 数组排列
  4. echo.
  5. echo 最大可支持10位 输入时以空格键隔开
  6. echo.
  7. set /p str=输入数组:
  8. echo.
  9. echo 原数组为%str%.
  10. set n=0
  11. for %%i in (%str%) do (
  12. set/a n+=1
  13. set str[!n!]=         %%i
  14. )
  15. for /l %%i in (1,1,%n%) do echo !str[%%i]:~-10!>>1.txt
  16. echo.
  17. echo.
  18. echo 现数组为:
  19. sort 1.txt
  20. set /p a=按回车键结束
  21. del 1.txt
复制代码
o(∩_∩)o...~~~
空间:http://hi.baidu.com/fair_jm
喜欢批处理的没事的话去逛逛哦~~

TOP

先来两种方法

一、冒泡法:
  1. @echo off&setlocal enabledelayedexpansion
  2. for %%i in (3 2008 11 19 777 23 2014 453 789 51) do set "str=!str! #%%i#"
  3. set "var=%str%"
  4. for %%a in (%str%) do (
  5.     for %%i in (!var!) do (
  6.         set "a=%%a"&set "b=%%i"
  7.         set "a=!a:#=!"&set "b=!b:#=!"
  8.         if !a! gtr !b! (
  9.         set "var=!var:%%a =!"
  10.         set "var=!var:%%i=%%i %%a!"
  11.         )
  12.     )
  13. )
  14. echo %var:#=%&pause>nul
复制代码
二、补位法:
  1. @echo off&setlocal enabledelayedexpansion
  2. for /l %%i in (1,1,80) do set "bw=!bw!0"
  3. for %%i in (3 2008 11 19 777 23 2014 453 789 51) do (
  4.      set "str=%bw%%%i"
  5.      set "_!str:~-80!=%%i"
  6. )
  7. for /f "tokens=2 delims==" %%i in ('set _') do set /p=%%i <nul
  8. pause>nul
复制代码

[ 本帖最后由 batman 于 2008-8-22 14:18 编辑 ]
1

评分人数

    • keen: 补位法最帅!!!PB + 6
***共同提高***

TOP

不知是否符合题意
  1. @echo off&setlocal enabledelayedexpansion
  2. set "p=3 2008 11 19 777 23 2014 453 789 51"
  3. for %%i in (%p%) do (
  4.    set t=1
  5.    for %%r in (%p%) do (
  6.        if %%i gtr %%r set /a t=!t!+1
  7.    )
  8. set !t!=%%i
  9. )
  10. echo !1! !2! !3! !4! !5! !6! !7! !8! !9! !10!
  11. pause
复制代码
3

评分人数

TOP

问题出来了,
虽然偏方的代码不长,但是如果排序的数字 有几个是相同滴咋办

TOP

原帖由 terse 于 2008-8-21 14:01 发表
还是用补位效率高
…… set .!str:~-10! !random!=%%i……

这里random是否起着一定作用。

TOP

返回列表