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; } }