在c++中找到substring

在C++中,我想实现这样一个功能:在给定的字符串string中,如果出现一个我给定的substring,就返回一种值,如果没有出现,就返回另一种值。我想用s.find功能,但是失败了,它只能实现一个字符串的查找,无法处理多个字符串,这该怎么办呢?

bool check(string s)
{
    string::size_type position;
    position = s.find("IIII");
    //position = s.find("XXXX");
    /*position = s.find("CCCC");
    position = s.find("MMMM");
    position = s.find("VV");
    position = s.find("LL");
    position = s.find("DD");
    position = s.find("IL");
    position = s.find("IC");
    position = s.find("ID");
    position = s.find("IM");
    position = s.find("XM");
    position = s.find("VX");
    position = s.find("VL");
    position = s.find("VC");
    position = s.find("VD");
    position = s.find("VM");
    position = s.find("LC");
    position = s.find("LD");
    position = s.find("LM");
    position = s.find("DM");*/
    
   if (position == s.npos) 
    {
       return true; 
    }
    
    else
    {
        return false;
    }
}

如代码所示,我在处理非法的罗马数字,如果出现以下几种情况就判断为非法,我该怎么办呢?

substring "IIII"等字符串存到数组里,循环遍历find