Problem A: 自定义字符串的下标运算
作者:互联网
Description
定义类MyString,由长度不超过100的字符串组成。重载其下标运算符:
int operator[](char ch)
用于重复求指定字符ch在串中的下标。
重载其输入运算符,用于输入字符串。
Input
输入一个不含空白符的字符串(长度不超过100个)和一个字符。
Output
指定字符在字符串中的所有位置。
Sample Input
babababaab a
Sample Output
1
3
5
7
8
-1
HINT
下标运算符中需要用到静态变量。
禁止使用STL,包括list、vector和string等。
Append Code
int main()
{
MyString mystr;
char c;
int pos;
cin>>mystr>>c;
do{
pos = mystr[c];
cout<<pos<<endl;
}while(pos != -1);
return 0;
}
Accepted Code
#include<iostream>
using namespace std;
class MyString
{
private:
char mystr[101];
public:
static int t;
friend istream& operator >>(istream&,MyString&);
int operator[](char ch)
{
while(mystr[t]!='\0')
{
if(mystr[t]==ch)
{
t++;
return t-1;
}
else
{
t++;
}
}
return -1;
}
};
int MyString::t=0;
istream &operator>>(istream &is,MyString &c)
{
char mystr[101];
is>>c.mystr;
return is;
}
int main()
{
MyString mystr;
char c;
int pos;
cin>>mystr>>c;
do
{
pos = mystr[c];
cout<<pos<<endl;
}
while(pos != -1);
return 0;
}
标签:ch,下标,自定义,int,pos,char,MyString,Problem,mystr 来源: https://blog.csdn.net/weixin_52540973/article/details/121707373