字符串函数---strcmp()与strncmp()详解及实现【转】
本文转载自:http://blog.csdn.net/lanzhihui_10086/article/details/39829623
一、strcmp()与strncmp()
strcmp():strcmp(s1,s2); 比较两个字符串。
strncmp():strncmp(s1,s2); 比较两个字符串前n位
比较规则:从左到右逐个字符进行比较(ASCII值),直到出现不同的字符或遇到'\0'为止。
如果全部的字符相同,则认为两字符串相等,返回值为0;
如果出现不同的字符,则对第一次出现不同的字符进行比较,比较方法是以s1的第一个不同的字符减去s2的第一个不同的字符,以所得差值作为返回值(大于0,则返回1,小于0则返回-1)。
代码实例:
- #include<iostream>
- #include<assert.h>
- using namespace std;
- int main()
- {
- char a[]="aaaae";
- char b[]="aaaaf";
- int i=strcmp(a,b);
- cout<<i<<endl;
- int j=strncmp(a,b,4);//只比较前n个字符
- cout<<j<<endl;
- system("pause");
- return 0;
- }
运行结果为 -1,0;
二、strcmp()与strncmp()的具体实现
- #include<iostream>
- #include<assert.h>
- using namespace std;
- int strcmp_m(const char *s1,const char *s2)
- {
- assert((s1!=NULL)&&(s2!=NULL));
- while(*s1!='\0'&&*s2!='\0')//字符串前面部分都相同
- {
- if(*s1-*s2>0)
- return 1;
- if(*s1-*s2<0)
- return -1;
- s1++;
- s2++;
- }
- if(*s1=='\0'&&*s2!='\0')//谁先为'\0',谁就小
- return -1;
- if(*s2=='\0'&&*s1!='\0')
- return 1;
- return 0; //同时为'\0'
- }
- int strncmp_m(const char *s1,const char *s2,int n)
- {
- assert((s1!=NULL)&&(s2!=NULL));
- while(*s1!='\0'&&*s2!='\0'&&n)//字符串前面部分都相同
- {
- if(*s1-*s2>0)
- return 1;
- if(*s1-*s2<0)
- return -1;
- s1++;
- s2++;
- n--;
- }
- if(*s1=='\0'&&*s2!='\0')//谁先为'\0',谁就小
- return -1;
- if(*s2=='\0'&&*s1!='\0')
- return 1;
- return 0; //同时为'\0'
- }
- int main()
- {
- char a[]="aaaae";
- char b[]="aaaaf";
- int i=strcmp_m(a,b);
- cout<<i<<endl;
- int j=strncmp_m(a,b,4);//只比较前n个字符
- cout<<j<<endl;
- system("pause");
- return 0;
- }
运行结果为 -1,0,实现了strcmp()函数与strncmp()函数的功能。
字符串函数---strcmp()与strncmp()详解及实现【转】的更多相关文章
- Linux C 字符串函数 sprintf()、snprintf() 详解
一.sprintf() 函数详解 在将各种类 型的数据构造成字符串时,sprintf 的强大功能很少会让你失望. 由于 sprintf 跟 printf 在用法上几乎一样,只是打印的目的地不同而已,前 ...
- 字符串函数---strcmp()与strncmp()具体解释及实现
一.strcmp()与strncmp() strcmp():strcmp(s1,s2); 比較两个字符串. strncmp():strncmp(s1,s2); ...
- [转载]Linux C 字符串函数 sprintf()、snprintf() 详解
一.sprintf() 函数详解 在将各种类 型的数据构造成字符串时,sprintf 的强大功能很少会让你失望. 由于 sprintf 跟 printf 在用法上几乎一样,只是打印的目的地不同而已,前 ...
- JS函数动作分层结构详解及Document.getElementById 释义 js及cs数据类型区别 事件 函数 变量 script标签 var function
html +css 静态页面 js 动态 交互 原理: js就是修改样式, 比如弹出一个对话框. 弹出的过程就是这个框由disable 变成display:enable. 又或者当鼠标指向 ...
- WordPress函数:get_bloginfo()用法详解
描述 返回你博客的信息,这些信息可以用在任何地方的 PHP 代码中.这个函数,和 bloginfo() 一样,可以用来在模板文件的任何地方显示你博客的信息. 用法 <?php $bloginfo ...
- Delphi Format函数功能及用法详解
DELPHI中Format函数功能及用法详解 DELPHI中Format函数功能及用法详解function Format(const Format: string; const Args: array ...
- PHP函数call_user_func和call_user_func_array详解
今天在群里面,有个叫lewis的在问call_user_func_array的用法,因为之前一直没有用过,也不能说什么,于是看一下手册,发现是这么写的: call_user_func_array (P ...
- Wordpress菜单函数wp_nav_menu各参数详解及示例
Wordpress菜单函数wp_nav_menu各参数详解及示例 注册菜单 首先要注册菜单,将以下函数添加至function.php函数里 register_nav_menus(array( ...
- Vue钩子函数生命周期实例详解
vue生命周期简介 Vue实例有一个完整的生命周期,也就是从开始创建.初始化数据.编译模板.挂载Dom.渲染→更新→渲染.卸载等一系列过程,我们称这是Vue的生命周期.通俗说就是Vue实例从创建到销毁 ...
随机推荐
- 小白写的一个ASP.NET分页控件,仅供娱乐
无聊,第一次写博客,自己动手写了一个分页控件.由于我是新手,有很多地方写得不够好,希望各位大牛多多指正.哈哈哈 /// <summary> /// 分页控件 /// </summar ...
- vue vuex初学基础 常见错误解决方式
前端界面使用篇 vue生命周期初始化事件 http://www.cnblogs.com/lily1010/p/5830946.html 常见错误篇 1 Newline required at end ...
- elasticearch 归并策略
归并线程配置 segment 归并的过程,需要先读取 segment,归并计算,再写一遍 segment,最后还要保证刷到磁盘.可以说,这是一个非常消耗磁盘 IO 和 CPU 的任务.所以,ES 提供 ...
- node 连接MySQL及其分装, 连接池连接
const mysql = require('mysql') const config = require('./../../config/config.default') var connectio ...
- Deutsch lernen (11)
1. anwesend a. 出席的,在场的 ~ abwesend Es waren gegen 50 Leute anwesend. 2. gespannt a. (心情)急切的,急于想知道的:紧张 ...
- redis与其可视化工具在win7上的安装
步骤 1.下载安装Redis服务. 2.调用执行文件创建服务器以及测试缓存. 3.使用可视化工具redis-desktop-manager管理查询缓存. 1.下载安装Redis服务. 下载地址:htt ...
- 微信小程序swiper bindChange重复执行
swiper是微信小程序的一个滑动组件,非常重要.如果只是做简单的轮播图而不进行复杂的逻辑,直接可以使用,甚至不需要知道组件的方法.今天在做一个如下的页面时,快速滑动swiper出现了问题: 控制台打 ...
- HTML 1.1页面js修改文字颜色
昨天的报告页面,想要实现根据不同文字内容改变字体颜色,效果图: 调试了半天出不来效果,最后请教了前端,上代码: <!DOCTYPE html> <html lang="en ...
- UNIX C 进程Part2
1.获取进程ID #include <unistd.h> pid_t getpid(void); //获取子进程id pid_t getppid(void);//获取父进程id 2.获取实 ...
- [POI2010] Intelligence test
yyl说是用链表O(n)做 但是并脑补不出来. 发现可以用个vector记录一下每个数出现的位置,然后对于每个新序列就二分一下,找下一个数出现的离当前位置最近的位置,更新一下当前位置即可. 时间复杂度 ...