免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: 3P党人
打印 上一主题 下一主题

[数值计算] 新手求代码优化 [复制链接]

论坛徽章:
2
白羊座
日期:2013-11-18 19:52:42辰龙
日期:2014-09-07 07:46:06
11 [报告]
发表于 2013-10-22 11:23 |只看该作者
Shell_HAT 发表于 2013-10-22 09:51
用汇编来实现的话,我赶脚应该可以更快一点。


同意,如果也能在几分钟内给出代码,并执行成功的话,也是一种不错的选择。

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
12 [报告]
发表于 2013-10-22 11:48 |只看该作者
对你的代码稍微调整了一下,省去
  1. str="$str${chs:$((RANDOM % LEN)):1}"
复制代码
可能可以快个1%
  1. #!/bin/bash

  2. chs='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!@#$%^&*_-+=:;.?/~`,'
  3. LINE_COUNT=$((200 * 10000))
  4. STRING_LEN=70
  5. LEN=${#chs}

  6. for ((i = 0; i < LINE_COUNT; i++)); do
  7.     for ((j = 0; j < STRING_LEN; j++)); do
  8.         echo -n "${chs:$((RANDOM % LEN)):1}"
  9.     done
  10.     echo ""
  11. done
复制代码

论坛徽章:
0
13 [报告]
发表于 2013-10-22 18:28 |只看该作者
rdcwayx 发表于 2013-10-22 11:48
对你的代码稍微调整了一下,省去可能可以快个1%



版主牛!

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
14 [报告]
发表于 2013-10-23 07:43 |只看该作者
@damcool@3P党人
damcool 的代码在我的环境里的运行速度:
  1. time tr -dc 'a-zA-Z!@#$%^&*\_\-\+=:;.?/~`,' </dev/urandom|head -c $((200*70*10000))|fold -w 70 &>/dev/null

  2. real    0m32.813s
  3. user    0m39.434s
  4. sys     0m3.886s
复制代码
看样子,damcool的硬件环境要比我快很多啊。

论坛徽章:
2
白羊座
日期:2013-11-18 19:52:42辰龙
日期:2014-09-07 07:46:06
15 [报告]
发表于 2013-10-23 08:04 |只看该作者
rdcwayx 发表于 2013-10-23 07:43
@damcool@3P党人
damcool 的代码在我的环境里的运行速度:看样子,damcool的硬件环境要比我快很多啊。

应该这么说/dev/urandom产生的字符很随机,不是每次运行结果都一样的。因为/dev/urandom产生的字符只有符合给定字符集的才保留,所以最坏的情况很长时间没有符合的字符出来。

论坛徽章:
0
16 [报告]
发表于 2013-10-23 09:27 |只看该作者
本帖最后由 3P党人 于 2013-10-23 09:29 编辑
rdcwayx 发表于 2013-10-23 07:32
@3P党人

大概找出原因,改成让fold 来管理换行会快很多。



版主,是这句
  1. str="$str${chs:$((RANDOM % LEN)):1}"
复制代码
导致的暴慢吗?


另外,看起来你的脚本规模比我小了 69 倍?

论坛徽章:
0
17 [报告]
发表于 2013-10-23 10:51 |只看该作者
rdcwayx 发表于 2013-10-23 09:49
str 这句的改动可以稍微减少些运行时间。 你的代码里用时比较多的,是两次for loop.

我给改成一次for l ...


问题是输出的规模不等价

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
18 [报告]
发表于 2013-10-23 11:20 |只看该作者
回复 21# 3P党人
是的, 我的代码有问题, 已经删去,免得误解。

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP