鱼C论坛

 找回密码
 立即注册
查看: 2157|回复: 1

[已解决]c作业指针数组和数组指针——矩阵倒置出错

[复制链接]
发表于 2019-9-21 22:03:26 | 显示全部楼层 |阅读模式
5鱼币
本帖最后由 乐知者 于 2019-9-21 22:33 编辑
  1. #include <stdio.h>

  2. int main()
  3. {
  4.         char *array[5] = {"FishC", "Five", "Star", "Good", "WoW"};
  5.         char *(*p)[5] = &array;   
  6.         int i, j;

  7.         for (i = 0; i < 5; i++)
  8.         {
  9.                
  10.                 for (j = 0; (*p)[i][j] != '\0'; j++)
  11.                 {
  12.                        
  13.                     printf("%c ", (*p)[j][i]);
  14.                 }
  15.                 printf("\n");
  16.         }

  17.         return 0;
  18. }
复制代码

原本倒置过来应该是这样的 042952n9h9h9189h998888.png

然而我的代码输出是这样的 2019-09-21 (2).png

最右侧少了o和w

为什么会这样呢?求大佬指教



以下是正确代码:
  1. #include <stdio.h>
  2. #include <string.h>

  3. int main()
  4. {
  5.         char *array[5] = {"FishC", "Five", "Star", "Good", "Wow"};
  6.         char *(*p)[5] = &array;
  7.         int i, j;

  8.         for (i = 0; i < 5; i++)
  9.         {
  10.                 for (j = 0; j < 5; j++)
  11.                 {
  12.                         if (i > strlen((*p)[j]) - 1)                   //这一行是什么意思呢?
  13.                         {
  14.                                 break;
  15.                         }
  16.                         printf("%c ", (*p)[j][i]);
  17.                 }
  18.                 printf("\n");
  19.         }

  20.         return 0;
  21. }
复制代码


  if (i > strlen((*p)[j]) - 1)这一行看不懂啊,不明白什么意思,大佬顺便帮忙解答一下吧
最佳答案
2019-9-21 22:03:27
本帖最后由 superbe 于 2019-9-22 08:25 编辑

这个程序的思路是”行列交换法”,就是将(i,j)位置的字符换成(j,i)位置的字符,这两个字符关于(从左上角到右下角的)对角线对称。但是这样交换行列输出时要考虑特殊情况。
如下图,为了便于说明问题,我把原始矩阵最后的字符串WoW,改成了只有一个字母W(红虚线是对角线)。
无标题.png
图上(2,4)这个位置是\0,本来应该输出(4,2)的字符,可是(4,2)这个位置是什么呢,(看图上箭头)这个位置已经超过字符串"W"的长度了,是无意义的未知字符,所以就应该跳过不输出。
这就是正确代码14行的作用,它判断要输出的字符是否超过字符串长度,超过了就不输出。

再说你原来的代码,下图是原始矩阵:
无标题2.PNG
循环到(1,4)位置时正好是\0,(看图上箭头)应该输出(4,1)的o了,但是代码判断(*p)[ i ][ j ] !='\0'才输出,导致o没有输出。同理,(2,4)对称的(4,2)字符w也没出输出。

最佳答案

查看完整内容

这个程序的思路是”行列交换法”,就是将(i,j)位置的字符换成(j,i)位置的字符,这两个字符关于(从左上角到右下角的)对角线对称。但是这样交换行列输出时要考虑特殊情况。 如下图,为了便于说明问题,我把原始矩阵最后的字符串WoW,改成了只有一个字母W(红虚线是对角线)。 图上(2,4)这个位置是\0,本来应该输出(4,2)的字符,可是(4,2)这个位置是什么呢,(看图上箭头)这个位置已经超过字符串"W"的长度了,是无意义的未知字符,所 ...
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-9-21 22:03:27 | 显示全部楼层    本楼为最佳答案   
本帖最后由 superbe 于 2019-9-22 08:25 编辑

这个程序的思路是”行列交换法”,就是将(i,j)位置的字符换成(j,i)位置的字符,这两个字符关于(从左上角到右下角的)对角线对称。但是这样交换行列输出时要考虑特殊情况。
如下图,为了便于说明问题,我把原始矩阵最后的字符串WoW,改成了只有一个字母W(红虚线是对角线)。
无标题.png
图上(2,4)这个位置是\0,本来应该输出(4,2)的字符,可是(4,2)这个位置是什么呢,(看图上箭头)这个位置已经超过字符串"W"的长度了,是无意义的未知字符,所以就应该跳过不输出。
这就是正确代码14行的作用,它判断要输出的字符是否超过字符串长度,超过了就不输出。

再说你原来的代码,下图是原始矩阵:
无标题2.PNG
循环到(1,4)位置时正好是\0,(看图上箭头)应该输出(4,1)的o了,但是代码判断(*p)[ i ][ j ] !='\0'才输出,导致o没有输出。同理,(2,4)对称的(4,2)字符w也没出输出。

评分

参与人数 1荣誉 +5 鱼币 +3 贡献 +3 收起 理由
乐知者 + 5 + 3 + 3 谢谢大佬,解释的非常清楚^_^

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-3 02:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表