#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll p = 1e9 + 7;
int n, m;
ll dp[305][305];
ll dp1[305][305];
int main() {
  cin >> n >> m;
  dp[1][0] = 1;
  for (int i = 1; i <= m; ++i) {
    memset(dp1, 0, sizeof(dp1));
    for (int j = 1; j <= i; ++j)
      for (int k = 0; k <= i - j; ++k) {
        if (k == 0) {
          dp1[j][k] = (dp1[j][k] + j * dp[j][k]) % p;
          dp1[j][k + 1] = (dp1[j][k + 1] + (n - j) * dp[j][k]) % p;
        } else {
          dp1[j][k] = (dp1[j][k] + k * dp[j][k]) % p;
          dp1[j + k][0] = (dp1[j + k][0] + j * dp[j][k]) % p;
          dp1[j][k + 1] = (dp1[j][k + 1] + (n - j - k) * dp[j][k]) % p;
        }
      }
    memcpy(dp, dp1, sizeof(dp));
  }
  cout << dp[n][0] << endl;
}