|
发表于 2023-11-13 22:39:31
|
显示全部楼层
这段代码的问题在于,它没有正确处理当n为偶数时最后一个中心元素的情况。当n为偶数时,最后一个中心元素不会被正确填充。
为了解决这个问题,我们需要在每一层循环结束后,检查是否还有剩余的中心元素需要填充,并在需要的情况下进行填充。
以下是修改后的代码:
- #include <stdio.h>
- int main() {
- int n, i, j, num = 1, layer;
- int a[10][10];
- scanf("%d", &n);
- for (layer = 0; layer < (n + 1) / 2; layer++) {
- for (j = layer; j <= n - layer - 1; j++) { // 上边
- a[layer][j] = num++;
- }
- for (i = layer + 1; i <= n - layer - 1; i++) { // 右边
- a[ i][n - layer - 1] = num++;
- }
- for (j = n - layer - 2; j >= layer; j--) { // 下边
- a[n - layer - 1][j] = num++;
- }
- for (i = n - layer - 2; i > layer; i--) { // 左边
- a[ i][layer] = num++;
- }
- }
- // 处理中心元素
- if (n % 2 == 1) {
- a[n / 2][n / 2] = num;
- }
- for (i = 0; i < n; i++) {
- for (j = 0; j < n; j++) {
- printf("%2d ", a[ i][j]);
- }
- printf("\n");
- }
- return 0;
- }
复制代码
这样修改后的代码会正确处理当n为偶数时的情况,确保中心元素也能被正确填充。 |
|