1 //===----------------------------------------------------------------------===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is dual licensed under the MIT and the University of Illinois Open 6 // Source Licenses. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 10 // <string> 11 12 // size_type find_last_not_of(const charT* s, size_type pos, size_type n) const; 13 14 #include <string> 15 #include <cassert> 16 17 template <class S> 18 void 19 test(const S& s, const typename S::value_type* str, typename S::size_type pos, 20 typename S::size_type n, typename S::size_type x) 21 { 22 assert(s.find_last_not_of(str, pos, n) == x); 23 if (x != S::npos) 24 assert(x <= pos && x < s.size()); 25 } 26 27 typedef std::string S; 28 29 void test0() 30 { 31 test(S(""), "", 0, 0, S::npos); 32 test(S(""), "irkhs", 0, 0, S::npos); 33 test(S(""), "kante", 0, 1, S::npos); 34 test(S(""), "oknlr", 0, 2, S::npos); 35 test(S(""), "pcdro", 0, 4, S::npos); 36 test(S(""), "bnrpe", 0, 5, S::npos); 37 test(S(""), "jtdaefblso", 0, 0, S::npos); 38 test(S(""), "oselktgbca", 0, 1, S::npos); 39 test(S(""), "eqgaplhckj", 0, 5, S::npos); 40 test(S(""), "bjahtcmnlp", 0, 9, S::npos); 41 test(S(""), "hjlcmgpket", 0, 10, S::npos); 42 test(S(""), "htaobedqikfplcgjsmrn", 0, 0, S::npos); 43 test(S(""), "hpqiarojkcdlsgnmfetb", 0, 1, S::npos); 44 test(S(""), "dfkaprhjloqetcsimnbg", 0, 10, S::npos); 45 test(S(""), "ihqrfebgadntlpmjksoc", 0, 19, S::npos); 46 test(S(""), "ngtjfcalbseiqrphmkdo", 0, 20, S::npos); 47 test(S(""), "", 1, 0, S::npos); 48 test(S(""), "lbtqd", 1, 0, S::npos); 49 test(S(""), "tboim", 1, 1, S::npos); 50 test(S(""), "slcer", 1, 2, S::npos); 51 test(S(""), "cbjfs", 1, 4, S::npos); 52 test(S(""), "aqibs", 1, 5, S::npos); 53 test(S(""), "gtfblmqinc", 1, 0, S::npos); 54 test(S(""), "mkqpbtdalg", 1, 1, S::npos); 55 test(S(""), "kphatlimcd", 1, 5, S::npos); 56 test(S(""), "pblasqogic", 1, 9, S::npos); 57 test(S(""), "arosdhcfme", 1, 10, S::npos); 58 test(S(""), "blkhjeogicatqfnpdmsr", 1, 0, S::npos); 59 test(S(""), "bmhineprjcoadgstflqk", 1, 1, S::npos); 60 test(S(""), "djkqcmetslnghpbarfoi", 1, 10, S::npos); 61 test(S(""), "lgokshjtpbemarcdqnfi", 1, 19, S::npos); 62 test(S(""), "bqjhtkfepimcnsgrlado", 1, 20, S::npos); 63 test(S("eaint"), "", 0, 0, 0); 64 test(S("binja"), "gfsrt", 0, 0, 0); 65 test(S("latkm"), "pfsoc", 0, 1, 0); 66 test(S("lecfr"), "tpflm", 0, 2, 0); 67 test(S("eqkst"), "sgkec", 0, 4, S::npos); 68 test(S("cdafr"), "romds", 0, 5, 0); 69 test(S("prbhe"), "qhjistlgmr", 0, 0, 0); 70 test(S("lbisk"), "pedfirsglo", 0, 1, 0); 71 test(S("hrlpd"), "aqcoslgrmk", 0, 5, 0); 72 test(S("ehmja"), "dabckmepqj", 0, 9, S::npos); 73 test(S("mhqgd"), "pqscrjthli", 0, 10, 0); 74 test(S("tgklq"), "kfphdcsjqmobliagtren", 0, 0, 0); 75 test(S("bocjs"), "rokpefncljibsdhqtagm", 0, 1, 0); 76 test(S("grbsd"), "afionmkphlebtcjqsgrd", 0, 10, 0); 77 test(S("ofjqr"), "aenmqplidhkofrjbctsg", 0, 19, S::npos); 78 test(S("btlfi"), "osjmbtcadhiklegrpqnf", 0, 20, S::npos); 79 test(S("clrgb"), "", 1, 0, 1); 80 test(S("tjmek"), "osmia", 1, 0, 1); 81 test(S("bgstp"), "ckonl", 1, 1, 1); 82 test(S("hstrk"), "ilcaj", 1, 2, 1); 83 test(S("kmspj"), "lasiq", 1, 4, 1); 84 test(S("tjboh"), "kfqmr", 1, 5, 1); 85 test(S("ilbcj"), "klnitfaobg", 1, 0, 1); 86 test(S("jkngf"), "gjhmdlqikp", 1, 1, 1); 87 test(S("gfcql"), "skbgtahqej", 1, 5, 1); 88 test(S("dqtlg"), "bjsdgtlpkf", 1, 9, 1); 89 test(S("bthpg"), "bjgfmnlkio", 1, 10, 1); 90 test(S("dgsnq"), "lbhepotfsjdqigcnamkr", 1, 0, 1); 91 test(S("rmfhp"), "tebangckmpsrqdlfojhi", 1, 1, 1); 92 test(S("jfdam"), "joflqbdkhtegimscpanr", 1, 10, S::npos); 93 test(S("edapb"), "adpmcohetfbsrjinlqkg", 1, 19, S::npos); 94 test(S("brfsm"), "iacldqjpfnogbsrhmetk", 1, 20, S::npos); 95 test(S("ndrhl"), "", 2, 0, 2); 96 test(S("mrecp"), "otkgb", 2, 0, 2); 97 test(S("qlasf"), "cqsjl", 2, 1, 2); 98 test(S("smaqd"), "dpifl", 2, 2, 2); 99 test(S("hjeni"), "oapht", 2, 4, 2); 100 test(S("ocmfj"), "cifts", 2, 5, 2); 101 test(S("hmftq"), "nmsckbgalo", 2, 0, 2); 102 test(S("fklad"), "tpksqhamle", 2, 1, 2); 103 test(S("dirnm"), "tpdrchmkji", 2, 5, 1); 104 test(S("hrgdc"), "ijagfkblst", 2, 9, 1); 105 test(S("ifakg"), "kpocsignjb", 2, 10, 2); 106 test(S("ebrgd"), "pecqtkjsnbdrialgmohf", 2, 0, 2); 107 test(S("rcjml"), "aiortphfcmkjebgsndql", 2, 1, 2); 108 test(S("peqmt"), "sdbkeamglhipojqftrcn", 2, 10, 2); 109 test(S("frehn"), "ljqncehgmfktroapidbs", 2, 19, S::npos); 110 test(S("tqolf"), "rtcfodilamkbenjghqps", 2, 20, S::npos); 111 test(S("cjgao"), "", 4, 0, 4); 112 test(S("kjplq"), "mabns", 4, 0, 4); 113 test(S("herni"), "bdnrp", 4, 1, 4); 114 test(S("tadrb"), "scidp", 4, 2, 4); 115 test(S("pkfeo"), "agbjl", 4, 4, 4); 116 test(S("hoser"), "jfmpr", 4, 5, 3); 117 test(S("kgrsp"), "rbpefghsmj", 4, 0, 4); 118 test(S("pgejb"), "apsfntdoqc", 4, 1, 4); 119 test(S("thlnq"), "ndkjeisgcl", 4, 5, 4); 120 test(S("nbmit"), "rnfpqatdeo", 4, 9, 3); 121 test(S("jgmib"), "bntjlqrfik", 4, 10, 2); 122 test(S("ncrfj"), "kcrtmpolnaqejghsfdbi", 4, 0, 4); 123 test(S("ncsik"), "lobheanpkmqidsrtcfgj", 4, 1, 4); 124 test(S("sgbfh"), "athdkljcnreqbgpmisof", 4, 10, 3); 125 test(S("dktbn"), "qkdmjialrscpbhefgont", 4, 19, 2); 126 test(S("fthqm"), "dmasojntqleribkgfchp", 4, 20, S::npos); 127 test(S("klopi"), "", 5, 0, 4); 128 test(S("dajhn"), "psthd", 5, 0, 4); 129 test(S("jbgno"), "rpmjd", 5, 1, 4); 130 test(S("hkjae"), "dfsmk", 5, 2, 4); 131 } 132 133 void test1() 134 { 135 test(S("gbhqo"), "skqne", 5, 4, 4); 136 test(S("ktdor"), "kipnf", 5, 5, 4); 137 test(S("ldprn"), "hmrnqdgifl", 5, 0, 4); 138 test(S("egmjk"), "fsmjcdairn", 5, 1, 4); 139 test(S("armql"), "pcdgltbrfj", 5, 5, 3); 140 test(S("cdhjo"), "aekfctpirg", 5, 9, 4); 141 test(S("jcons"), "ledihrsgpf", 5, 10, 3); 142 test(S("cbrkp"), "mqcklahsbtirgopefndj", 5, 0, 4); 143 test(S("fhgna"), "kmlthaoqgecrnpdbjfis", 5, 1, 4); 144 test(S("ejfcd"), "sfhbamcdptojlkrenqgi", 5, 10, 1); 145 test(S("kqjhe"), "pbniofmcedrkhlstgaqj", 5, 19, 2); 146 test(S("pbdjl"), "mongjratcskbhqiepfdl", 5, 20, S::npos); 147 test(S("gajqn"), "", 6, 0, 4); 148 test(S("stedk"), "hrnat", 6, 0, 4); 149 test(S("tjkaf"), "gsqdt", 6, 1, 4); 150 test(S("dthpe"), "bspkd", 6, 2, 4); 151 test(S("klhde"), "ohcmb", 6, 4, 4); 152 test(S("bhlki"), "heatr", 6, 5, 4); 153 test(S("lqmoh"), "pmblckedfn", 6, 0, 4); 154 test(S("mtqin"), "aceqmsrbik", 6, 1, 4); 155 test(S("dpqbr"), "lmbtdehjrn", 6, 5, 4); 156 test(S("kdhmo"), "teqmcrlgib", 6, 9, 4); 157 test(S("jblqp"), "njolbmspac", 6, 10, 3); 158 test(S("qmjgl"), "pofnhidklamecrbqjgst", 6, 0, 4); 159 test(S("rothp"), "jbhckmtgrqnosafedpli", 6, 1, 4); 160 test(S("ghknq"), "dobntpmqklicsahgjerf", 6, 10, 1); 161 test(S("eopfi"), "tpdshainjkbfoemlrgcq", 6, 19, S::npos); 162 test(S("dsnmg"), "oldpfgeakrnitscbjmqh", 6, 20, S::npos); 163 test(S("jnkrfhotgl"), "", 0, 0, 0); 164 test(S("dltjfngbko"), "rqegt", 0, 0, 0); 165 test(S("bmjlpkiqde"), "dashm", 0, 1, 0); 166 test(S("skrflobnqm"), "jqirk", 0, 2, 0); 167 test(S("jkpldtshrm"), "rckeg", 0, 4, 0); 168 test(S("ghasdbnjqo"), "jscie", 0, 5, 0); 169 test(S("igrkhpbqjt"), "efsphndliq", 0, 0, 0); 170 test(S("ikthdgcamf"), "gdicosleja", 0, 1, 0); 171 test(S("pcofgeniam"), "qcpjibosfl", 0, 5, S::npos); 172 test(S("rlfjgesqhc"), "lrhmefnjcq", 0, 9, S::npos); 173 test(S("itphbqsker"), "dtablcrseo", 0, 10, 0); 174 test(S("skjafcirqm"), "apckjsftedbhgomrnilq", 0, 0, 0); 175 test(S("tcqomarsfd"), "pcbrgflehjtiadnsokqm", 0, 1, 0); 176 test(S("rocfeldqpk"), "nsiadegjklhobrmtqcpf", 0, 10, 0); 177 test(S("cfpegndlkt"), "cpmajdqnolikhgsbretf", 0, 19, S::npos); 178 test(S("fqbtnkeasj"), "jcflkntmgiqrphdosaeb", 0, 20, S::npos); 179 test(S("shbcqnmoar"), "", 1, 0, 1); 180 test(S("bdoshlmfin"), "ontrs", 1, 0, 1); 181 test(S("khfrebnsgq"), "pfkna", 1, 1, 1); 182 test(S("getcrsaoji"), "ekosa", 1, 2, 0); 183 test(S("fjiknedcpq"), "anqhk", 1, 4, 1); 184 test(S("tkejgnafrm"), "jekca", 1, 5, 0); 185 test(S("jnakolqrde"), "ikemsjgacf", 1, 0, 1); 186 test(S("lcjptsmgbe"), "arolgsjkhm", 1, 1, 1); 187 test(S("itfsmcjorl"), "oftkbldhre", 1, 5, 0); 188 test(S("omchkfrjea"), "gbkqdoeftl", 1, 9, 1); 189 test(S("cigfqkated"), "sqcflrgtim", 1, 10, S::npos); 190 test(S("tscenjikml"), "fmhbkislrjdpanogqcet", 1, 0, 1); 191 test(S("qcpaemsinf"), "rnioadktqlgpbcjsmhef", 1, 1, 1); 192 test(S("gltkojeipd"), "oakgtnldpsefihqmjcbr", 1, 10, S::npos); 193 test(S("qistfrgnmp"), "gbnaelosidmcjqktfhpr", 1, 19, S::npos); 194 test(S("bdnpfcqaem"), "akbripjhlosndcmqgfet", 1, 20, S::npos); 195 test(S("ectnhskflp"), "", 5, 0, 5); 196 test(S("fgtianblpq"), "pijag", 5, 0, 5); 197 test(S("mfeqklirnh"), "jrckd", 5, 1, 5); 198 test(S("astedncjhk"), "qcloh", 5, 2, 5); 199 test(S("fhlqgcajbr"), "thlmp", 5, 4, 5); 200 test(S("epfhocmdng"), "qidmo", 5, 5, 5); 201 test(S("apcnsibger"), "lnegpsjqrd", 5, 0, 5); 202 test(S("aqkocrbign"), "rjqdablmfs", 5, 1, 4); 203 test(S("ijsmdtqgce"), "enkgpbsjaq", 5, 5, 5); 204 test(S("clobgsrken"), "kdsgoaijfh", 5, 9, 3); 205 test(S("jbhcfposld"), "trfqgmckbe", 5, 10, 5); 206 test(S("oqnpblhide"), "igetsracjfkdnpoblhqm", 5, 0, 5); 207 test(S("lroeasctif"), "nqctfaogirshlekbdjpm", 5, 1, 5); 208 test(S("bpjlgmiedh"), "csehfgomljdqinbartkp", 5, 10, 1); 209 test(S("pamkeoidrj"), "qahoegcmplkfsjbdnitr", 5, 19, S::npos); 210 test(S("espogqbthk"), "dpteiajrqmsognhlfbkc", 5, 20, S::npos); 211 test(S("shoiedtcjb"), "", 9, 0, 9); 212 test(S("ebcinjgads"), "tqbnh", 9, 0, 9); 213 test(S("dqmregkcfl"), "akmle", 9, 1, 9); 214 test(S("ngcrieqajf"), "iqfkm", 9, 2, 9); 215 test(S("qosmilgnjb"), "tqjsr", 9, 4, 9); 216 test(S("ikabsjtdfl"), "jplqg", 9, 5, 8); 217 test(S("ersmicafdh"), "oilnrbcgtj", 9, 0, 9); 218 test(S("fdnplotmgh"), "morkglpesn", 9, 1, 9); 219 test(S("fdbicojerm"), "dmicerngat", 9, 5, 8); 220 test(S("mbtafndjcq"), "radgeskbtc", 9, 9, 9); 221 test(S("mlenkpfdtc"), "ljikprsmqo", 9, 10, 9); 222 test(S("ahlcifdqgs"), "trqihkcgsjamfdbolnpe", 9, 0, 9); 223 test(S("bgjemaltks"), "lqmthbsrekajgnofcipd", 9, 1, 9); 224 test(S("pdhslbqrfc"), "jtalmedribkgqsopcnfh", 9, 10, 9); 225 test(S("dirhtsnjkc"), "spqfoiclmtagejbndkrh", 9, 19, 3); 226 test(S("dlroktbcja"), "nmotklspigjrdhcfaebq", 9, 20, S::npos); 227 test(S("ncjpmaekbs"), "", 10, 0, 9); 228 test(S("hlbosgmrak"), "hpmsd", 10, 0, 9); 229 test(S("pqfhsgilen"), "qnpor", 10, 1, 9); 230 test(S("gqtjsbdckh"), "otdma", 10, 2, 9); 231 test(S("cfkqpjlegi"), "efhjg", 10, 4, 9); 232 test(S("beanrfodgj"), "odpte", 10, 5, 9); 233 test(S("adtkqpbjfi"), "bctdgfmolr", 10, 0, 9); 234 test(S("iomkfthagj"), "oaklidrbqg", 10, 1, 9); 235 } 236 237 void test2() 238 { 239 test(S("sdpcilonqj"), "dnjfsagktr", 10, 5, 8); 240 test(S("gtfbdkqeml"), "nejaktmiqg", 10, 9, 9); 241 test(S("bmeqgcdorj"), "pjqonlebsf", 10, 10, 8); 242 test(S("etqlcanmob"), "dshmnbtolcjepgaikfqr", 10, 0, 9); 243 test(S("roqmkbdtia"), "iogfhpabtjkqlrnemcds", 10, 1, 9); 244 test(S("kadsithljf"), "ngridfabjsecpqltkmoh", 10, 10, 7); 245 test(S("sgtkpbfdmh"), "athmknplcgofrqejsdib", 10, 19, 5); 246 test(S("qgmetnabkl"), "ldobhmqcafnjtkeisgrp", 10, 20, S::npos); 247 test(S("cqjohampgd"), "", 11, 0, 9); 248 test(S("hobitmpsan"), "aocjb", 11, 0, 9); 249 test(S("tjehkpsalm"), "jbrnk", 11, 1, 9); 250 test(S("ngfbojitcl"), "tqedg", 11, 2, 9); 251 test(S("rcfkdbhgjo"), "nqskp", 11, 4, 9); 252 test(S("qghptonrea"), "eaqkl", 11, 5, 7); 253 test(S("hnprfgqjdl"), "reaoicljqm", 11, 0, 9); 254 test(S("hlmgabenti"), "lsftgajqpm", 11, 1, 9); 255 test(S("ofcjanmrbs"), "rlpfogmits", 11, 5, 9); 256 test(S("jqedtkornm"), "shkncmiaqj", 11, 9, 7); 257 test(S("rfedlasjmg"), "fpnatrhqgs", 11, 10, 8); 258 test(S("talpqjsgkm"), "sjclemqhnpdbgikarfot", 11, 0, 9); 259 test(S("lrkcbtqpie"), "otcmedjikgsfnqbrhpla", 11, 1, 9); 260 test(S("cipogdskjf"), "bonsaefdqiprkhlgtjcm", 11, 10, 8); 261 test(S("nqedcojahi"), "egpscmahijlfnkrodqtb", 11, 19, S::npos); 262 test(S("hefnrkmctj"), "kmqbfepjthgilscrndoa", 11, 20, S::npos); 263 test(S("atqirnmekfjolhpdsgcb"), "", 0, 0, 0); 264 test(S("echfkmlpribjnqsaogtd"), "prboq", 0, 0, 0); 265 test(S("qnhiftdgcleajbpkrosm"), "fjcqh", 0, 1, 0); 266 test(S("chamfknorbedjitgslpq"), "fmosa", 0, 2, 0); 267 test(S("njhqpibfmtlkaecdrgso"), "qdbok", 0, 4, 0); 268 test(S("ebnghfsqkprmdcljoiat"), "amslg", 0, 5, 0); 269 test(S("letjomsgihfrpqbkancd"), "smpltjneqb", 0, 0, 0); 270 test(S("nblgoipcrqeaktshjdmf"), "flitskrnge", 0, 1, 0); 271 test(S("cehkbngtjoiflqapsmrd"), "pgqihmlbef", 0, 5, 0); 272 test(S("mignapfoklbhcqjetdrs"), "cfpdqjtgsb", 0, 9, 0); 273 test(S("ceatbhlsqjgpnokfrmdi"), "htpsiaflom", 0, 10, 0); 274 test(S("ocihkjgrdelpfnmastqb"), "kpjfiaceghsrdtlbnomq", 0, 0, 0); 275 test(S("noelgschdtbrjfmiqkap"), "qhtbomidljgafneksprc", 0, 1, 0); 276 test(S("dkclqfombepritjnghas"), "nhtjobkcefldimpsaqgr", 0, 10, 0); 277 test(S("miklnresdgbhqcojftap"), "prabcjfqnoeskilmtgdh", 0, 19, S::npos); 278 test(S("htbcigojaqmdkfrnlsep"), "dtrgmchilkasqoebfpjn", 0, 20, S::npos); 279 test(S("febhmqtjanokscdirpgl"), "", 1, 0, 1); 280 test(S("loakbsqjpcrdhftniegm"), "sqome", 1, 0, 1); 281 test(S("reagphsqflbitdcjmkno"), "smfte", 1, 1, 1); 282 test(S("jitlfrqemsdhkopncabg"), "ciboh", 1, 2, 0); 283 test(S("mhtaepscdnrjqgbkifol"), "haois", 1, 4, 0); 284 test(S("tocesrfmnglpbjihqadk"), "abfki", 1, 5, 1); 285 test(S("lpfmctjrhdagneskbqoi"), "frdkocntmq", 1, 0, 1); 286 test(S("lsmqaepkdhncirbtjfgo"), "oasbpedlnr", 1, 1, 1); 287 test(S("epoiqmtldrabnkjhcfsg"), "kltqmhgand", 1, 5, 1); 288 test(S("emgasrilpknqojhtbdcf"), "gdtfjchpmr", 1, 9, 0); 289 test(S("hnfiagdpcklrjetqbsom"), "ponmcqblet", 1, 10, 0); 290 test(S("nsdfebgajhmtricpoklq"), "sgphqdnofeiklatbcmjr", 1, 0, 1); 291 test(S("atjgfsdlpobmeiqhncrk"), "ljqprsmigtfoneadckbh", 1, 1, 1); 292 test(S("sitodfgnrejlahcbmqkp"), "ligeojhafnkmrcsqtbdp", 1, 10, 0); 293 test(S("fraghmbiceknltjpqosd"), "lsimqfnjarbopedkhcgt", 1, 19, S::npos); 294 test(S("pmafenlhqtdbkirjsogc"), "abedmfjlghniorcqptks", 1, 20, S::npos); 295 test(S("pihgmoeqtnakrjslcbfd"), "", 10, 0, 10); 296 test(S("gjdkeprctqblnhiafsom"), "hqtoa", 10, 0, 10); 297 test(S("mkpnblfdsahrcqijteog"), "cahif", 10, 1, 10); 298 test(S("gckarqnelodfjhmbptis"), "kehis", 10, 2, 10); 299 test(S("gqpskidtbclomahnrjfe"), "kdlmh", 10, 4, 9); 300 test(S("pkldjsqrfgitbhmaecno"), "paeql", 10, 5, 10); 301 test(S("aftsijrbeklnmcdqhgop"), "aghoqiefnb", 10, 0, 10); 302 test(S("mtlgdrhafjkbiepqnsoc"), "jrbqaikpdo", 10, 1, 10); 303 test(S("pqgirnaefthokdmbsclj"), "smjonaeqcl", 10, 5, 10); 304 test(S("kpdbgjmtherlsfcqoina"), "eqbdrkcfah", 10, 9, 8); 305 test(S("jrlbothiknqmdgcfasep"), "kapmsienhf", 10, 10, 10); 306 test(S("mjogldqferckabinptsh"), "jpqotrlenfcsbhkaimdg", 10, 0, 10); 307 test(S("apoklnefbhmgqcdrisjt"), "jlbmhnfgtcqprikeados", 10, 1, 10); 308 test(S("ifeopcnrjbhkdgatmqls"), "stgbhfmdaljnpqoicker", 10, 10, 8); 309 test(S("ckqhaiesmjdnrgolbtpf"), "oihcetflbjagdsrkmqpn", 10, 19, S::npos); 310 test(S("bnlgapfimcoterskqdjh"), "adtclebmnpjsrqfkigoh", 10, 20, S::npos); 311 test(S("kgdlrobpmjcthqsafeni"), "", 19, 0, 19); 312 test(S("dfkechomjapgnslbtqir"), "beafg", 19, 0, 19); 313 test(S("rloadknfbqtgmhcsipje"), "iclat", 19, 1, 19); 314 test(S("mgjhkolrnadqbpetcifs"), "rkhnf", 19, 2, 19); 315 test(S("cmlfakiojdrgtbsphqen"), "clshq", 19, 4, 19); 316 test(S("kghbfipeomsntdalrqjc"), "dtcoj", 19, 5, 17); 317 test(S("eldiqckrnmtasbghjfpo"), "rqosnjmfth", 19, 0, 19); 318 test(S("abqjcfedgotihlnspkrm"), "siatdfqglh", 19, 1, 19); 319 test(S("qfbadrtjsimkolcenhpg"), "mrlshtpgjq", 19, 5, 19); 320 test(S("abseghclkjqifmtodrnp"), "adlcskgqjt", 19, 9, 19); 321 test(S("ibmsnlrjefhtdokacqpg"), "drshcjknaf", 19, 10, 19); 322 test(S("mrkfciqjebaponsthldg"), "etsaqroinghpkjdlfcbm", 19, 0, 19); 323 test(S("mjkticdeoqshpalrfbgn"), "sgepdnkqliambtrocfhj", 19, 1, 19); 324 test(S("rqnoclbdejgiphtfsakm"), "nlmcjaqgbsortfdihkpe", 19, 10, 18); 325 test(S("plkqbhmtfaeodjcrsing"), "racfnpmosldibqkghjet", 19, 19, 7); 326 test(S("oegalhmstjrfickpbndq"), "fjhdsctkqeiolagrnmbp", 19, 20, S::npos); 327 test(S("rdtgjcaohpblniekmsfq"), "", 20, 0, 19); 328 test(S("ofkqbnjetrmsaidphglc"), "ejanp", 20, 0, 19); 329 test(S("grkpahljcftesdmonqib"), "odife", 20, 1, 19); 330 test(S("jimlgbhfqkteospardcn"), "okaqd", 20, 2, 19); 331 test(S("gftenihpmslrjkqadcob"), "lcdbi", 20, 4, 18); 332 test(S("bmhldogtckrfsanijepq"), "fsqbj", 20, 5, 18); 333 test(S("nfqkrpjdesabgtlcmoih"), "bigdomnplq", 20, 0, 19); 334 test(S("focalnrpiqmdkstehbjg"), "apiblotgcd", 20, 1, 19); 335 test(S("rhqdspkmebiflcotnjga"), "acfhdenops", 20, 5, 18); 336 test(S("rahdtmsckfboqlpniegj"), "jopdeamcrk", 20, 9, 18); 337 test(S("fbkeiopclstmdqranjhg"), "trqncbkgmh", 20, 10, 17); 338 test(S("lifhpdgmbconstjeqark"), "tomglrkencbsfjqpihda", 20, 0, 19); 339 } 340 341 void test3() 342 { 343 test(S("pboqganrhedjmltsicfk"), "gbkhdnpoietfcmrslajq", 20, 1, 19); 344 test(S("klchabsimetjnqgorfpd"), "rtfnmbsglkjaichoqedp", 20, 10, 19); 345 test(S("sirfgmjqhctndbklaepo"), "ohkmdpfqbsacrtjnlgei", 20, 19, 1); 346 test(S("rlbdsiceaonqjtfpghkm"), "dlbrteoisgphmkncajfq", 20, 20, S::npos); 347 test(S("ecgdanriptblhjfqskom"), "", 21, 0, 19); 348 test(S("fdmiarlpgcskbhoteqjn"), "sjrlo", 21, 0, 19); 349 test(S("rlbstjqopignecmfadkh"), "qjpor", 21, 1, 19); 350 test(S("grjpqmbshektdolcafni"), "odhfn", 21, 2, 19); 351 test(S("sakfcohtqnibprjmlged"), "qtfin", 21, 4, 19); 352 test(S("mjtdglasihqpocebrfkn"), "hpqfo", 21, 5, 19); 353 test(S("okaplfrntghqbmeicsdj"), "fabmertkos", 21, 0, 19); 354 test(S("sahngemrtcjidqbklfpo"), "brqtgkmaej", 21, 1, 19); 355 test(S("dlmsipcnekhbgoaftqjr"), "nfrdeihsgl", 21, 5, 18); 356 test(S("ahegrmqnoiklpfsdbcjt"), "hlfrosekpi", 21, 9, 19); 357 test(S("hdsjbnmlegtkqripacof"), "atgbkrjdsm", 21, 10, 19); 358 test(S("pcnedrfjihqbalkgtoms"), "blnrptjgqmaifsdkhoec", 21, 0, 19); 359 test(S("qjidealmtpskrbfhocng"), "ctpmdahebfqjgknloris", 21, 1, 19); 360 test(S("qeindtagmokpfhsclrbj"), "apnkeqthrmlbfodiscgj", 21, 10, 19); 361 test(S("kpfegbjhsrnodltqciam"), "jdgictpframeoqlsbknh", 21, 19, 7); 362 test(S("hnbrcplsjfgiktoedmaq"), "qprlsfojamgndekthibc", 21, 20, S::npos); 363 } 364 365 int main() 366 { 367 test0(); 368 test1(); 369 test2(); 370 test3(); 371 } 372