当前位置: 首页 > article >正文

【id:14】【20分】C. 字符串比较(指针与字符)

题目描述

编写一个函数比较两个字符串,参数是两个字符指针(要求显式定义,例如char *S, char *T),比较字符串S和T的大小。如果S大于T,则返回1,如果S小于T则返回-1,如果S与T相等则返回0。

比较规则:

1.把两个字符串的相同位置上的字符进行比较,字符的大小比较以ASCII值为准

2.在比较中,如果字符串S的字符大于字符串T的字符的数量超过小于的数量,则认为S大于T,如果等于则S等于T,如果小于则S小于T

例如S为aaccdd,T为eebbbb,每个位置比较得到S前两个字母都小于T,但后4个字母都大于T,最终认为S大于T

3.如果两个字符串长度不同,则更长的字符串为大

在主函数中输入两个字符串,并调用该函数进行判断,在判断函数中必须使用函数参数的指针进行字符比较

输入

输入t表示有t个测试实例

接着每两行输入两个字符串,字符串的最大长度不超过20

依次输入t个实例

输出

每行输出一个实例的比较结果


输入样例1

3
aaccdd
eebbbb
AAbb++
aaEE*-
zznnkk
aaaaaaa
 


输出样例1

1
0
-1
 


输入样例2

2
aaaaaaa
zznnkk
eebbbb
aaccdd


输出样例2

1
-1


 

#include<iostream>
#include<string.h>
using namespace std;

void fn(char* S, char* T)
{
    //3.如果两个字符串长度不同,则更长的字符串为大
    if (strlen(S) > strlen(T))
    {
        cout<< 1 << endl;
    }
    //strlen(S)可以求字符串长度 头文件 #include<string.h> 计算指定字符串的长度,但不包括结束字符。
    else if (strlen(S)<strlen(T))
    {
        cout<< -1<< endl;
    }
    //相同长度情况下
    else
    {
        int s1 = 0, s2 = 0;
        for (int i = 0; i < strlen(S); i++)
        {
            if (S[i] > T[i])
                s1++;
            else if (S[i]< T[i])
                s2++;
        }
        if (s1>s2)cout<< 1 <<endl;
        else if (s1<s2) cout<< -1 << endl;
        else cout<<0 <<endl;
    }
}

int main()
{
    int t;
    cin>> t;
    while (t--)
    {
        char* S = new char[100];
        char* T = new char[100];
        cin>> S>>T;
        fn(S, T);
    }

}

tip: strlen()可以求字符串长度 头文件 #include<string.h> 计算指定字符串的长度,但不包括结束字符。


http://www.kler.cn/a/1987.html

相关文章:

  • 使用 Buildroot 构建带有 Avahi 支持的 Linux 系统
  • 【自动化】Python SeleniumUtil 工具 开启开发者模式 自动安装油猴用户脚本等
  • Vue3之路由(Router)介绍
  • BenchmarkSQL使用教程
  • Go 1.24即将到来!
  • PostgreSQL技术内幕21:SysLogger日志收集器的工作原理
  • 强烈推荐:0基础入门网安必备《网络安全知识图谱》
  • 企业站项目
  • unordered系列的关联式容器介绍
  • 计算机网络复习重点
  • ChatGPT4已经来了,30秒做一个弹球游戏!
  • 8个python自动化脚本提高打工人幸福感~比心~
  • 今年好像没有金三银四了?
  • Pandas 与 PySpark 强强联手,功能与速度齐飞
  • map和set的使用指南
  • 电脑技巧:常见的浏览器内核介绍
  • Cookie和Session详解
  • 基于YOLOv5的疲劳驾驶检测系统(Python+清新界面+数据集)
  • PCL 使用ICP点云拼接
  • 如何监控和诊断JVM堆内和堆外内存使用?
  • 简单三步解决动态规划难题,记好这三步,动态规划就不难
  • 图神经网络的数学原理总结
  • JavaSE思维导图——总结篇
  • 前端已死?后端已亡?弯弯绕绕,几分真几分假
  • HCIE-Cloud Computing LAB备考第二步:逐题攻破--第五题:规划--根据网络平面规划表,完成ensp中接入交换机SW1/2的配置
  • GIS应用技巧之图斑四至坐标计算