⼆维字符串C语⾔,c语⾔⼆维字符数组寻字符串回复 3楼 诸葛欧阳
不⾏。。。。显⽰0个,这个程序我也快做好了,就差如果是回⽂的时候要除以2了。。。。。
#include
#include
int main()
{
char str[110][110],s[110];
int m,n,i,j,k,count=0,a,b;
while(scanf("%d %d",&n,&m)!=EOF)
{
for(i=0;i
{
for(j=0;j<=m;j++)
{
scanf("%c",&str[i][j]);
}
if(i==(n-1)&&j==m)
{
str[i][j]='\0';
}
}
getchar();
gets(s);
for(a=0;s[a]!='\0';a++)
{}
for(i=0;i
{
for(j=0;j
{
if(str[i][j]==s[0])
{
for(k=0;;k++)
if(str[i][j+k]==s[k])
{
continue;
}
if(s[k]==s[a])
{
count++;
}
if(str[i][j+k]!=s[k])
{
break;
}
}
}
}
}printf("1:%d\n",count); for(i=0;i
{
for(j=0;j
{
if(str[j][i]==s[0])
{
for(k=0;;k++)
{
if(str[j+k][i]==s[k])
{
continue;
c语言如何创建字符串数组
}
if(s[k]==s[a])
{
count++;
}
if(str[j+k][i]!=s[k])
break;
}
}
}
}
}printf("2:%d\n",count); for(i=n;i>=0;i--)//3
{
for(j=m;j>=0;j--)
{
if(str[i][j]==s[0])
{
for(k=0;;k++)
{
if(str[i][j-k]==s[k])
{
continue;
}
if(s[k]==s[a])
{
count++;
}
if(str[i][j-k]!=s[k])
{
break;
}
}
}
}
}printf("3:%d\n",count); for(i=m;i>=0;i--)//4
{
for(j=n;j>=0;j--)
if(str[j][i]==s[0])
{
for(k=0;;k++)
{
if(str[j-k][i]==s[k])
{
continue;
}
if(s[a]==s[k])
{
count++;
}
if(str[j-k][i]!=s[k])
{
break;
}
}
}
}
}printf("4:%d\n",count); printf("%d\n",count); count=0;
}
return 0;
}

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。