18 已知下面的字符串是通过RANDOM随机数变量md5sum|cut-c 1-8截取后的结果

面试题18:破解RANDOM随机数案例

已知下面的字符串是通过RANDOM随机数变量md5sum后,再截取一部分连续字符串的结果,请破解这些字符串对应的使用md5sum处理前的RANDOM对应的数字?

21029299

00205d1c

a3da1677

1f6d12dd

890684b

 

[root@jenkins scripts]# cat aa.txt
21029299
00205d1c
a3da1677
1f6d12dd
890684b

[root@jenkins scripts]# cat rd_mat.sh 
#!/bin/bash
##############################################################
# File Name: rd_mat.sh
# Version: V1.0
# Author: gaobo
# Organization: 641627690@qq.com
# Created Time : 2017-12-07 19:57:59
# Description:
##############################################################

for ((i=0;i<=32767;i++))
do
     for j in `cat /server/scripts/aa.txt`
     do
           #echo "$(echo $i|md5sum|cut -c 1-8)    ${j}"
           if [ "$(echo $i|md5sum|cut -c 1-8)" == "${j}" ]
        then
        echo  $i
       fi
     done
    

done

 

[root@jenkins scripts]# sh rd_mat.sh
1346
7041
25345
25667

 

 

方法二:

 

[root@jenkins scripts]# cat rd_mat.sh 
#!/bin/bash
##############################################################
# File Name: rd_mat.sh
# Version: V1.0
# Author: gaobo
# Organization: 641627690@qq.com
# Created Time : 2017-12-07 19:57:59
# Description:
##############################################################

for ((i=0;i<=32767;i++))
do
     for j in `cat /server/scripts/aa.txt`
     do
           
           if [[ "$(echo $i|md5sum)" =~ "${j}" ]]
        then
        echo  $i
       fi
     done
    

done

 

现在每次分析网站日志的时候都需要判断百度蜘蛛是不是真实的蜘蛛,nslookup之后需要判断结果中是否包含“baidu”字符串

以下给出一些shell中判断字符串包含的方法,来源程序员问答网站 stackoverflow 以及segmentfault。

方法一:利用grep查找

 
strA="long string"
strB="string"
result=$(echo $strA | grep "${strB}")
if [[ "$result" != "" ]]
then
  echo "包含"
else
  echo "不包含"
fi
 

先打印长字符串,然后在长字符串中 grep 查找要搜索的字符串,用变量result记录结果

如果结果不为空,说明strA包含strB。如果结果为空,说明不包含。

这个方法充分利用了grep 的特性,最为简洁。

方法二:利用字符串运算符


 
strA="helloworld"
strB="low"
if [[ $strA =~ $strB ]]
then
  echo "包含"
else
  echo "不包含"
fi
 

利用字符串运算符 =~ 直接判断strA是否包含strB。(这不是比第一个方法还要简洁吗!)

方法三:利用通配符

 
A="helloworld"
B="low"
if [[ $A == *$B* ]]
then
  echo "包含"
else
  echo "不包含"
fi
 

这个也很easy,用通配符*号代理strA中非strB的部分,如果结果相等说明包含,反之不包含。

方法四:利用case in 语句


 
thisString="1 2 3 4 5" # 源字符串
searchString="1 2" # 搜索字符串
case $thisString in
  *"$searchString"*) echo Enemy Spot ;;
  *) echo nope ;;
esa
 

这个就比较复杂了,case in 我还没有接触到,不过既然有比较简单的方法何必如此

方法五:利用替换

 
STRING_A=$1
STRING_B=$2
if [[ ${STRING_A/${STRING_B}//} == $STRING_A ]]
  then
    ## is not substring.
    echo N
    return 0
  else
    ## is substring.
    echo Y
    return 1
  fi
 

这个也挺复杂

 

转载于:https://www.cnblogs.com/gaoyuechen/p/8000944.html

使用MA1LAB(假设这是一个编程环境,如MATLAB)生成符合均匀分布的随机数并进行分析的过程可以分为以下几个步骤: 1. **生成随机数**: 使用`rand(1, 30000)`函数可以得到一个1x30000的矩阵,每个元素都是0到1之间的均匀随机数。 ```matlab random_numbers = rand(1, 30000); ``` 2. **计算均值和标准方差**: - 均值(Mean)是所有数值加起来再除以总数量,标准方差(Standard Deviation)衡量数据点分散程度,可以用`mean`和`std`函数计算。 ```matlab mean_value = mean(random_numbers); std_dev = std(random_numbers); ``` 3. **查找最大和最小元素**: 可以直接通过`max`和`min`函数找到数组中的最大和最小值。 ```matlab max_element = max(random_numbers); min_element = min(random_numbers); ``` 4. **统计大于0.5的随机数占比**: 首先找出大于0.5的元素,然后除以总数乘以100%。 ```matlab above_half_count = sum(random_numbers > 0.5); percentage_above_half = above_half_count / length(random_numbers) * 100; ``` 将上述代码组合在一起: ```matlab % 生成随机数 random_numbers = rand(1, 30000); % 计算属性 mean_value = mean(random_numbers); std_dev = std(random_numbers); max_element = max(random_numbers); min_element = min(random_numbers); above_half_count = sum(random_numbers > 0.5); percentage_above_half = above_half_count / length(random_numbers) * 100; % 显示结果 disp("均值: " + mean_value); disp("标准方差: " + std_dev); disp("最大元素: " + max_element); disp("最小元素: " + min_element); disp("大于0.5的随机数占比: " + percentage_above_half + "%"); ``` 完成以上操作后,就可以查看随机数的统计特性了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值