| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 787 人关注过本帖
标题:关于字符型指针数组和字符型数组这样的等式为什么能成立
只看楼主 加入收藏
kknd84913
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2012-12-26
结帖率:0
收藏
 问题点数:0 回复次数:10 
关于字符型指针数组和字符型数组这样的等式为什么能成立
代码:
/*  在字符串数组中查找指定的字符串 */

#include "stdio.h"

main()
{
    int i,j;
    char chFind[4];
    char *chStr[4]={"Hello","All","The","World!",};
    printf("在字符串数组中查找指定的字符串\n\n");
    printf("原字符串数组是:\n");
    for(i=0;i<4;i++)
        printf("%s ",chStr[i]);
    printf("\n\n");
    printf("请输入要查询的字符串:\n");
    gets(chFind);
    for(i=0;i<4;i++)
    {
        for(j=0;j<4;j++)
        {
        if(*chStr[i]==chFind[j])
            printf("要查找的元素是字符型数组中的第%d位元素是:%s ",i+1,chStr[i]);
        }
    }
    printf("\n\n");

}
其中语句 if(*chStr[i]==chFind[j])
为什么能相等??一个元素是字符串,一个是单个字符在怎么等的起来??请明白的解答下  谢谢
搜索更多相关主题的帖子: 元素 字符串 include 查询 
2013-01-11 09:23
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
这个应该匹配失败吧。。。。

先说这句你就懂了

*chStr[i] == chFind[j]

左边是第 i个字符串,然后再取指向,默认取第一个字符

右边通过下标 j访问 chFind的某个字符,所以。

字符和字符当然可以比较了


[fly]存在即是合理[/fly]
2013-01-11 09:30
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
补充两句,,

你可以输入Abc测试一下

另外头文件用尖括号,用双引号的最好加路径


[fly]存在即是合理[/fly]
2013-01-11 09:34
kknd84913
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2012-12-26
收藏
得分:0 
回复 2楼 azzbcc
匹配是成功的  我都试过了 所以才不明白是怎么回事  虽然字符和字符可以比较 但是前者是默认指向第一个字符的  那么如果就算第一个字符是匹配成功的那么第二个字符怎么能成功呢??毕竟第二个的时候 J的下标变成了2  对应的是前者的第二个字符 那么除非前者指针也移动一次  不然在呢么能等,但是根据题目很明显内循环中只有后者下标在动  那又怎么能等的起来呢?除非是每次对比前者都读了一遍字符串 ,那么字符串又怎么能和字符对等起来呢?

[ 本帖最后由 kknd84913 于 2013-1-11 09:47 编辑 ]
2013-01-11 09:41
yaobao
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:蒙面侠
威 望:4
帖 子:1854
专家分:4121
注 册:2012-10-25
收藏
得分:0 
为什么不等呢?
字符串就是由字符加'\0'组成的一个数组,或者说你的字符串数组就是个字符的二维数组。
if(*chStr[i]==chFind[j])
chStr[i]是指向字符串数组第i个元素的指针,它指向首字母,那么对她取星就是字符串的首字母,字母和字母当然可以比较了。
就拿楼主的代码来测试,输入H,A,T,W,会有输出,因为他们是字符串的首元素,输入其他的就不会有输出

认认真真的学习,踏踏实实的走路:戒骄戒躁!!!
2013-01-11 09:50
kknd84913
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2012-12-26
收藏
得分:0 
回复 5楼 yaobao
哦 我明白了  其实这组循环只是提供了首字符的对比 其他的并没有进行比对。那么这组程序与原意还是有差距的,明白了 谢谢指教!
2013-01-11 10:04
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
你的代码循环了 16 次,比较了 16 次
其中if 左边依次为 HHHH TTTT AAAA WWWW

你大可输入 HHH 测试,肯定会输出 3次的

刚刚又注意到楼主一个错误,chFind[4],也就是说最多只能输入 3个字符,所以内循环条件 不对


[fly]存在即是合理[/fly]
2013-01-11 10:12
yaobao
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:蒙面侠
威 望:4
帖 子:1854
专家分:4121
注 册:2012-10-25
收藏
得分:0 
以下是引用kknd84913在2013-1-11 10:04:39的发言:

哦 我明白了  其实这组循环只是提供了首字符的对比 其他的并没有进行比对。那么这组程序与原意还是有差距的,明白了 谢谢指教!
DONT   too  客气

认认真真的学习,踏踏实实的走路:戒骄戒躁!!!
2013-01-11 10:18
kknd84913
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2012-12-26
收藏
得分:0 
回复 6楼 kknd84913
那么想再问下 有什么办法来查找指针型字符数组的元素呢?就是怎么判断char *chStr[4]数组中有我输入(或是想查找的)元素呢?毕竟char *chStr[4]中的元素只是指向首地址的那么除了第一个字符可以判断外同一个元素中的(字符串)后面的字母要怎么判断呢?

[ 本帖最后由 kknd84913 于 2013-1-11 10:22 编辑 ]
2013-01-11 10:19
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
用下标 chStr[i][j]


[fly]存在即是合理[/fly]
2013-01-11 11:21
快速回复:关于字符型指针数组和字符型数组这样的等式为什么能成立
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.025364 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved