题目描述
编写一个函数比较两个字符串,参数是两个字符指针(要求显式定义,例如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个测试实例
接着每两行输入两个字符串
依次输入t个实例
输出
每行输出一个实例的比较结果
输入样例1 输出样例1
3 1 -1
aaccdd 0
eebbbb -1
AAbb++
aaEE*-
zznnkkaaaaaaa
#include<bits/stdc++.h> using namespace std; void judge(char *p, char *q){ int account_1=0, account_2=0; //用于统计字符数 while(*p && *q){ if(*p > *q){ account_1 ++; } else if(*p < *q){ account_2 ++; } p++; q++; //地址均进行加一操作 } if(account_1 > account_2){ cout<<"1"<<endl; //S>T } else if(account_1 < account_2){ cout<<"-1"<<endl; //S<T } else cout<<"0"<<endl; //S=T } int main(){ int t; cin>>t; while(t--){ string S,T; cin>>S>>T; //首先需要判断两个字符串长度,该情况做出判断后在进行比较判断 if(S.size() == T.size() ) // char *p = &S[0], *q = &T[0]; judge(&S[0],&T[0]); //注意此处传入的地址为字符串首地址 //在字符串长度不想等时不需要进行字符判断 else if(S.size() > T.size() ) cout<<"1"<<endl; else cout<<"-1"<<endl; } return 0; }