让我们用字母 B
来表示“百”、字母 S
表示“十”,用 12...n
来表示不为零的个位数字 n
(<),换个格式来输出任一个不超过 3 位的正整数。例如 234
应该被输出为 BBSSS1234
,因为它有 2 个“百”、3 个“十”、以及个位的 4。
输入格式:
每个测试输入包含 1 个测试用例,给出正整数 n(<)。
输出格式:
每个测试用例的输出占一行,用规定的格式输出 n。
输入样例 1:
234
输出样例 1:
BBSSS1234
输入样例 2:
23
输出样例 2:
SS123
这里我采用的是获取位数上的数字然后做字符操作的办法,反正还是一如既往的全绿案例!阿希吧!
#!/bin/bash read n if [ $n -gt 0 -a $n -le 999 ] then B_w=$( echo "scale=0; $n / 100 "|bc) #浮点数计算expr不支持 S_w=$( echo "scale=0; ($n - $B_w * 100) / 10 "|bc) G_w=$( echo "scale=0; ($n - $B_w * 100 - $S_w * 10 ) "|bc) str1=$(seq -s 'B' $(expr $B_w + 1) |sed 's/[0-9]//g') #seq -s 可以将指定字符前插数字, 1a2a3 str2=$(seq -s 'S' $(expr $S_w + 1) |sed 's/[0-9]//g') i=1 for ((i >= 1; i <=$G_w ; i++ )) do str_t[ $(expr $i - 1) ]=$i done str3=$(echo ${str_t[@]} |sed 's/ //g') else echo "input number not in [0-999]" exit 1 fi echo ${str1}${str2}${str3}
修改了一下,通过数组和关联数组,使脚本扩展到13位数字的转换
#!/bin/bash read -t 10 -p "请输入需要转换的数字:" n W_n=(G S B Q W sw bw qw Y sy by qy wy) declare -A Num_p length=$(echo $n |awk '{print length($0)}') (( $n - 0 )); #算术运算 判断是否为数字 if [ $? -eq 0 ] && [ $length -lt 13 ] then i=0 for ((i >= 0;i < $length; i++ )) do a=$(expr $length - $i - 1 ) str[ $a ]=$(echo $n |cut -c $(expr $i + 1 )) #给数组str 按元素位置赋值 Num_p[$(echo ${W_n[$a]})]=${str[$a]} # echo "${W_n[$a]}: ${str[$a]}" if [[ "${W_n[$a]}x" == "Gx" ]] #判断个数位 then str_n[$i]=$(seq -s '' ${str[$a]} ) #个数位的数字自增,但个位为0的情况,此处为空 else str_n[$i]=$(seq -s "${W_n[$a]}" $(expr ${str[$a]} + 1) | sed 's/[0-9]//g') #把数组W_n的对应的值作为间隔符 fi done else echo " $n is out of range or no number!" exit 1 fi echo ${str_n[@]} | sed 's/ //g'