扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
录入两个字符串,一个字符串是另一个字符串的字串,输出子串首字母在长字符串的位置。
成都创新互联公司专注于企业全网整合营销推广、网站重做改版、武安网站定制设计、自适应品牌网站建设、HTML5建站、商城建设、集团公司官网建设、成都外贸网站制作、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为武安等各大城市提供网站开发制作服务。两个解决办法
使用库函数strncmp(str1,str2,n);
功能:比较str1和str2两个字符串的前n个字母,一一比较,若str1大则返回1,若str1和str2相等,则返回0,否则返回-1;
int compare(char *str1, char *str2) { int i; int lenstr1 = strlen(str1); int lenstr2 = strlen(str2); if( lenstr1< lenstr2) return -1;//录入str2为短字符串 for(i = 0; i <=lenstr1 - lenstr2; i++)//控制比较的次数 { if(strncmp(str1+i,str2,lenstr2) == 0)//每次将长的字符串比较的首字母前移一个 //比较的长度为短的字符串 return i;//返回首字母下标 } return -1; } 第二种方法,用for语句 void main() { char str1[100]; char str2[100]; int i, j, k; int shortstr, longstr, flag; gets(str1); gets(str2); shortstr = strlen(str2); longstr = strlen(str1); for(i = 0; i <= longstr - shortstr; i++ )//控制比较的次数 { k = i;//k是长字符串的比较首字母下标 for(j = 0; j < shortstr; j++)//每次都要依次比较短的字符串和长字符串中短字符串的个数 { if(str2[j]==str1[k]) flag++; k++; } if(flag == shortstr) printf("%d\n", i); else flag = 0; } }
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流