蓝桥杯练习系统(算法训练)ALGO-956 P0702 strcmp 函数

资源限制

内存限制:256.0MB C/C++时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s

在C语言中,有一个strcmp函数,其功能是比较两个字符串s1和s2。请编写一个你自己的字符串比较函数my_strcmp,来实现strcmp函数的类似功能。如果s1=s2,则返回0;否则返回s1 与s2 第一个不同字符的差值(如果s1<s2,该差值是一个负数;如果s1>s2,该差值是一个正数)。编写测试程序,输入两个长度小于1000的字符串(可能包含有空格,且长度不一定相等),然后调用my_strcmp函数来进行比较,并输出返回结果。
输入:

aBcDefgf

aacdef
输出 :

-31

cpp 复制代码
#include<iostream>
#include<string.h>
using namespace std;
const int N=1005;
char s1[N],s2[N];
int my_strcmp(char *s1,char *s2){
	int i=0,j=0;
	while(i<strlen(s1)&&j<strlen(s2)){
		if(s1[i]!=s2[j]) return s1[i]-s2[i];
		else{
			i++;
			j++;
		}
	}
	if(i<strlen(s1)) return s1[i];
	if(j<strlen(s2)) return 0-s2[j];
	if(i==strlen(s1)&&j==strlen(s2)) return 0;
}
int main(){
	char c;
	c=getchar();
	int cnt=0;
	while(c!='\n'){
		s1[cnt++]=c;
		c=getchar();
	} 
	char c1;
	c1=getchar();
	int cnt1=0;
	while(c1!='\n'){
		s2[cnt1++]=c1;
		c1=getchar();
	} 
	cout<<my_strcmp(s1,s2)<<endl;
	return 0;
}
相关推荐
sheeta19981 小时前
LeetCode 每日一题笔记 日期:2025.11.24 题目:1018. 可被5整除的二进制前缀
笔记·算法·leetcode
gfdhy7 小时前
【c++】哈希算法深度解析:实现、核心作用与工业级应用
c语言·开发语言·c++·算法·密码学·哈希算法·哈希
百***06017 小时前
SpringMVC 请求参数接收
前端·javascript·算法
一个不知名程序员www8 小时前
算法学习入门---vector(C++)
c++·算法
云飞云共享云桌面8 小时前
无需配置传统电脑——智能装备工厂10个SolidWorks共享一台工作站
运维·服务器·前端·网络·算法·电脑
福尔摩斯张8 小时前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
橘颂TA9 小时前
【剑斩OFFER】算法的暴力美学——两整数之和
算法·leetcode·职场和发展
xxxxxxllllllshi9 小时前
【LeetCode Hot100----14-贪心算法(01-05),包含多种方法,详细思路与代码,让你一篇文章看懂所有!】
java·数据结构·算法·leetcode·贪心算法
前端小L9 小时前
图论专题(二十二):并查集的“逻辑审判”——判断「等式方程的可满足性」
算法·矩阵·深度优先·图论·宽度优先
铁手飞鹰9 小时前
二叉树(C语言,手撕)
c语言·数据结构·算法·二叉树·深度优先·广度优先