#! /usr/bin/env bash

########################################################
#
#
########################################################
function solution_1() {
    grep tcp nowcoder.txt | awk -F":" '{print $2}' | awk '{print $2}' | sort | uniq -c | awk '{print $2,$1}' | sort -nr -k2
}

########################################################
#
#
########################################################
function solution_2() {
    awk '{
        if($1 == "tcp") {
            split($5, arr, ":");
            a[arr[1]]++;
        }
    } END {
        for(k in a) {
           print k,a[k]
       }
    }' nowcoder.txt | sort -nrk2
}

########################################################
#
#
########################################################
function solution_3() {
    local condition_index=${1}
    local target_index=${2}
    declare -A map
    local array=""
    local old_ifs=${IFS}
    while read line; do
        array=(${line})
        if [[ ${array[${condition_index}]} = "tcp" ]]; then
            IFS=":"
            array=(${array[${target_index}]})
            IFS="${old_ifs}"
            (( map["${array[0]}"]++ ))
        fi
    done < nowcoder.txt

    local tmp=(${map[@]})
    local size=${#tmp[@]}
    local int=0
    for (( i = 0; i < ${size}; i++ )); do
        for (( j = $i + 1; j < ${size}; j++ )); do
            [[ ${tmp[$i]} -ge ${tmp[$j]} ]] && continue
            int=${tmp[$i]}
            tmp[i]=${tmp[$j]}
            tmp[$j]=$int
        done
    done

    for (( i = 0; i < size; i++ )); do
        for va in ${!map[*]}; do
            [[ ${tmp[$i]} = ${map[$va]} ]] && printf "$va ${map[$va]}\n"
        done
    done
}

#solution_1
solution_2
# 有相同数量的结果,因此遍历输出是不正确的,有重复
#solution_3 0 4