import java.util.*;

public class Main {
    public static void main(String[] args) {
        // 标准输入
        Scanner input = new Scanner(System.in);
        // 获取矩阵的行数和列数
        int n = input.nextInt();
        int m = input.nextInt();
        // 初始化字符矩阵
        char[][] chars = new char[n+1][m+1];
        for (int i = 1; i <= n; i++) {
            String str = input.next(); // 获取当前行字符串
            for (int j = 1; j <= m; j++) {
                chars[i][j] = str.charAt(j-1);
            }
        }
        // dp[i][j]表示走到i行j列的时候,最多能获取多少分
        int[][] dp = new int[n+1][m+1];
        for (int i = 1; i <= n; i++) {
            for (int j = 1; j <= m; j++) {
                // 状态转移
                // 小红要么从左边格子到达当前位置,要么从上边格子到达当前位置
                dp[i][j] = Math.max(dp[i][j-1],dp[i-1][j]) + getScore(chars[i][j]);
            }
        }
        // 动态规划结束,输出结果
        System.out.println(dp[n][m]);     
    }

    // 判断选择某个字符时可以获得的分数
    private static int getScore(char c) {
        if(c=='l') return 4;
        if(c=='o') return 3;
        if(c=='v') return 2;
        if(c=='e') return 1;
        return 0;
    }
}