class Solution { public: vector<int> spiralOrder(vector<vector<int> > &matrix) { if (matrix.empty() || matrix[0].empty()) return {}; int m = matrix.size(), n = matrix[0].size(); vector<int> res; int c = m > n ? (n + 1) / 2 : (m + 1) / 2; int p = m, q = n; for (int i = 0; i < c; ++i, p -= 2, q -= 2) { for (int col = i; col < i + q; ++col) res.push_back(matrix[i][col]); for (int row = i + 1; row < i + p; ++row) res.push_back(matrix[row][i + q - 1]); if (p == 1 || q == 1) break; for (int col = i + q - 2; col >= i; --col) res.push_back(matrix[i + p - 1][col]); for (int row = i + p - 2; row > i; --row) res.push_back(matrix[row][i]); } return res; } };
还有一个知识点,也是相关的 ,就是比如在python中,我们定义一个list结构,append进去元素,那么我们在通过下标时可以快速的取元素,但是如果是直接从input中读取的,因为python把他们都当成string,所以直接通过下标走的就是string的下标路线,会直接把string的值按顺序输出,下面提供了一个可用的拆解代码,但还是要小心输入,输入皆为string
x=input() x=(x[1:-1]) for i in x.split(","): print(i)
另外自己写了一个softmax程序,涨知识在于自然对数e的指数形式可以用math或者numpy中的值来说。math要import,numpy要导包,两权相害我直接import了
愿为天下目,萃聚六路华
浙公网安备 33010602011771号