参考

    1.C++ 从入门到精通第三版;

    2.https://blog.csdn.net/liaoshengshi/article/details/45099923      如是多次被别人转载的地址并未侵权想法,没时间去找到底谁写的。

铺垫

    1. 在自学的过程中感觉一本好书真的可以节约很多时间,不幸的是...。。只怪当时随便买了一本还不是vs的编译环境。。。。

    2. 最近几天本来被指针,数组,指针的指针,指针数组搞得把自己学懵了,好不容感觉有了(希望自己有时间和闲心好好总结一番发到自己微博上),准备大开s戒的时候,就被一串代码卡住了,真是心态崩了。。。。

    3. 这个问题可能也只有我这种初学者有,如果下面这段代码的调试结果你完全没有疑问请大神跳过就好!不过还是想记录自己的学习过程。

代码: 

 1 #include <iostream>
2 using namespace std;
3 void sort(char *name[],int n) // 字符串排序
4 {
5 char *temp;
6 int i,j,k;
7 for(i=0;i<n-1;i++)
8 {
9 k=i;
10 for(j=i+1;j<n;j++)
11 //下面是自己想验证strcmp()后的结果
12 {
13 cout<< strcmp(name[k],name[j]) << endl;
14 if(strcmp(name[k],name[j])>0) { k=j; cout << "I am more than zero "<< endl; }
15
16 cout << "name[K]="<< name[k]<<" "<<"K="<< k<< " "<<"Kaddress:" << name + k << endl;
17 }
18 if(k!=i)
19 {
20 temp=name[i];name[i]=name[k];name[k]=temp;
21 }
22 }
23 }
24 void print(char *name[],int n) //输出字符串元素
25 {
26 int i=0;
27 char *p;
28 p=name[0];
29 while(i<n)
30 {
31 p=*(name+i++);
32 cout<<p<<endl;
33 }
34 }
35 int main( )
36 {
37 char *name[]={"mingri","soft","C++","mr"}; //定义指针数组
38 int n=4;
39
40 int m =0;
41
42 for (m; m< 4; m++)
43 //输出起始地址
44 {
45 cout << "first address:" << name + m<< endl;
46 }
47
48 sort(name,n);
49 print(name,n);
50 return 0;
51 }
52
53 /*
54 结果如下
55
56 first address:001AFE60
57 first address:001AFE64
58 first address:001AFE68
59 first address:001AFE6C
60 -1
61 name[K]=mingri K=0 Kaddress:001AFE60
62 1
63 I am more than zero
64 name[K]=C++ K=2 Kaddress:001AFE68
65 -1
66 name[K]=C++ K=2 Kaddress:001AFE68
67 1
68 I am more than zero
69 name[K]=mingri K=2 Kaddress:001AFE68
70 -1
71 name[K]=mingri K=2 Kaddress:001AFE68
72 1
73 I am more than zero
74 name[K]=mr K=3 Kaddress:001AFE6C
75 C++
76 mingri
77 mr
78 soft
79 Press any key to continue . . .
80
81
82 */

就是对这结果不满意:

            C++
            mingri
            mr
            soft

但对自己刚学的指针知识自认没毛病,如是开启了一大批验证代码尝试,有的在家电脑,一起都是这个结果没毛病啊!

(现在想想可能是自己学了matlab原因C++又不精吧,一直认为strcmp是比较字符串长度的,虽然知道这和matlab返回值是有区别的,也仅知道这些而已)

最后我认为一定是自己对strcmp()函数认识不够造成的;

最终找到一篇令自己豁然开朗的解释:

           strcmp函数是C/C++中基本的函数,它对两个字符串进行比较,然后返回比较结果,函数形式如下: int strcmp(const char* str1, const char* str2); 其中str1和str2可以是字符串常量或者字符串变量,返回值为整形。返回结果如下规定: ① str1小于str2,返回负值或者-1(VC返回-1);

② str1等于str2,返回0; ③ str1大于str2,返回正值或者1(VC返回1);

strcmp函数实际上是对字符的ASCII码进行比较,实现原理如下:首先比较两个串的第一个字符,若不相等,则停止比较并得出两个ASCII码大小比较的结果;如果相等就接着 比较第二个字符然后第三个字符等等。无论两个字符串是什么样,strcmp函数最多比较到其中一个字符串遇到结束符'/0'为止,就能得出结果。strcmp算法的可以有多种,不过我觉的可以把这么多算法分为两种,一种是利用减法运算判断结果,另一种是利用比较运算(==)得出结果。

分析:

  这段代码所谓的排序是ASCII码排序:C=67 ,m=109, o=111, r=114, s=115

就是这么简单;结果和我的想法达到了一直,认识了这个概念

这里写这么多两点欣喜:

            1. 解决了问题不论问题大小,说明还要多学啊,学海无涯。

            2. 跟自己刚学的指针没冲突,又进了一步。    

谢谢观赏!!!       

   

指针数组学习中的小插曲真是醉了-----Strcmp用法的更多相关文章

  1. Java 打印金字塔 or 打印带数字的金字塔 (Java 学习中的小记录)

    Java 打印金字塔 or 打印带数字的金字塔 (Java 学习中的小记录) 作者:王可利(Star·星星) 效果图: 代码如下: class Star8 { public static void m ...

  2. Java 需要记得、了解的关键词 (Java 学习中的小记录)

    Java 需要记得.了解的关键词 (Java 学习中的小记录)     作者:王可利(Star·星星) 总结:本次随笔,仅且拿来平时翻阅记忆用

  3. Java学习中,常用的命令管理(Java 学习中的小记录)

    Java学习中,常用的命令管理      作者:王可利(Star·星星) 一.Window中常见的dos命令 在哪里操作dos命令: Win7 ---> 开始  ---->所有程序---& ...

  4. Java 逻辑运算符、位运算符、移位操作符 总结(Java 学习中的小记录)

    Java 逻辑运算符.位运算符.移位操作符  总结     作者:王可利(Star·星星) 逻辑运算符,表格如下: 解析逻辑运算符表: 1.与 (&) 特点:两个都为真的时候,结果为真.两个为 ...

  5. spark学习中一些小问题---1

    1.linux文件查找命令.这个很关键 find / -name employees.json 2.hdfs命令上传整个文件夹或文件 hadoop dfs -put /home/root/apache ...

  6. Java数组学习之前基础小案例

    不多说,1天时间看完数组之前内容,这就靠代码的实践总结一下吧~~ 打印三角形 简单易懂,初学都会,就不注释了,前者为取巧的三角形实现方法,我注释了,直接上源码~~ public class Trian ...

  7. pytorch学习 中 torch.squeeze() 和torch.unsqueeze()的用法

    squeeze的用法主要就是对数据的维度进行压缩或者解压. 先看torch.squeeze() 这个函数主要对数据的维度进行压缩,去掉维数为1的的维度,比如是一行或者一列这种,一个一行三列(1,3)的 ...

  8. [C++学习历程]基础部分 C++中的指针数组和结构

    作者:苏生米沿 本文地址:http://blog.csdn.net/sushengmiyan/article/details/19938177 一.指针 对学习C++来说,指针是一项重要内容,以前,教 ...

  9. 记录Python学习中的几个小问题

    记录Python学习中的几个小问题,和C#\JAVA的习惯都不太一样. 1.Django模板中比较两个值是否相等 错误的做法 <option value="{{group.id}}&q ...

随机推荐

  1. Selenium使用cookis登录,并临时将cookis存储在本地【shelve数据库】

    Python中自带了一个shelve库,可以帮助我们存储一些少量的数据. shelve数据库类似redis,是以[键值对]的方式进行数据的存储,有点像"字典"这种数据结构,存储在本 ...

  2. Burst

    Unity Burst 用户指南 https://blog.csdn.net/alph258/article/details/83997917 Burst https://unity3d.com/cn ...

  3. mac:app已损坏,打不开。你应该将它移到废纸篓。

    app已损坏,打不开.你应该将它移到废纸篓. http://bbs.feng.com/read-htm-tid-11230947.html http://www.codesec.net/view/50 ...

  4. Springboot-Mybatis-进阶

    目录 数据库关系 ResultMap association collection 动态sql if where set choose foreach 缓存 一级缓存 二级缓存 开启二级缓存 配置 异 ...

  5. Webpack 入门指迷

    大概算是一份教程吧, 只不过效果肯定不如视频演示之类的好..Webpack 最近在英文社区上经常看到, 留了心, 但进一步了解是通过下边的视频:视频: How Instagram.com Works, ...

  6. Activiti7 网关(并行网关)

    什么是并行网关? 并行网关允许将流程分成多条分支,也可以将多条分支合并到一起,并行网关是基于进入和外出顺序流的 fork分支: 并行后的所有外出顺序流,为每个顺序流都创建一个并发分支 jion汇聚: ...

  7. [Java数据结构]Queue

    Queue扩展了Collection,它添加了支持根据先进先出FIFO原则对元素排序的方法. 当对Queue调用add和offer方法时,元素始终添加在Queue的末尾:要检索一个元素,就要使用一个元 ...

  8. 关于Vue的那些事儿

    Vue 渐进式框架 众前端周知,Vue是一套用于构建用户界面的渐进式框架,自底向上逐层应用,关注视图层.那我们就来说道说道: 渐进式:声明式渲染->组件系统->客户端路由(router)- ...

  9. 一个SQL查询连续三天的流量100以上的数据值【SQql Server】

    题目 有一个商场,每日人流量信息被记录在这三列信息中:序号 (id).日期 (date). 人流量 (people).请编写一个查询语句,找出高峰期时段,要求连续三天及以上,并且每天人流量均不少于10 ...

  10. Linux搭建SonarQube

    环境:linux+jdk8+mysql5.7.31+sonarqube7.5+sonar-scanner-4.4+jenkins2.249+sonar-l10n-zh-plugin-1.25.jar ...