我有一个简单的柱状图是这样的:搜索最小值为直方图
1.5 1.34
2.5 5.23
3.5 7.34
4.5 4.23
5.5 3.23
6.5 2.22
7.5 1.94
8.5 5.43
9.5 9.13
我需要找到第二列这是第一个最大的山谷后的最低谷,并打印出第一的相应值科拉姆。所以我应该得到这个输出:
7.5 1.94
任何人都可以提出一个很好的解决方案吗?
我有一个简单的柱状图是这样的:搜索最小值为直方图
1.5 1.34
2.5 5.23
3.5 7.34
4.5 4.23
5.5 3.23
6.5 2.22
7.5 1.94
8.5 5.43
9.5 9.13
我需要找到第二列这是第一个最大的山谷后的最低谷,并打印出第一的相应值科拉姆。所以我应该得到这个输出:
7.5 1.94
任何人都可以提出一个很好的解决方案吗?
awk 'NR == 1 {mx=$1;my=$2}
$2 < my {mx=$1;my=$2}
$2 == my && $1 > mx {mx=$1;my=$2}
END{print mx " " my}'
awk 'NR == 1 {my=$2;max_found=0}
!max_found && $2 > my {my=$2}
!max_found && $2 < my {mx=$1;my=$2;max_found=1}
max_found && $2 < my {mx=$1;my=$2}
max_found && $2 > my {exit}
END{print mx " " my}'
这可能会为你工作:
sort -k2,2n file | awk 'NR<2{max=$1} FNR<NR && $2>=max{print;exit}' file -
或本:
awk 'NR<2{max=$1}$2<max{next}min==0{line=$0;min=$2}$2<min{line=$0;min=$2}END{print line}' file
感谢,但对于浮点值。我更新了这个要求的帖子... – user1116360 2012-02-17 20:11:00
它接缝,我没有正确理解问题。即将推出新解 – jfg956 2012-02-17 20:20:24