请问大神我这道题的算法错在哪里?
【题目】
Description
一组长度大于3的数字序列,对于除了首尾两个数字,满足前后的数字都大于或都小于该数的数字叫做活跃数。
现在将一组序列加密为弓形矩阵,求解码后的序列有多少个活跃数。
Input
多组测试,输入矩阵的行数和列数分别为n,m,接着输入n*m个数字(2<=n,m<=20)
Output
输出一共有多少个活跃数。
Sample Input
3 2
1 2
4 3
5 6
Sample Output
0
HINT
解码后的序列为1 2 3 4 5 6,所以没有活跃数
【我的算法】
#include <stdio.h>
int main()
{
int n,m;
while(scanf("%d %d",&n,&m)!=EOF)
{
int i,j,k=0,a[20][20],b[400];
for(i=0;i<n;i++)
for(j=0;j<m;j++)
scanf("%d",&a[i][j]);
for(i=0;i<n;i++)
if(i%2==0)
for(j=0;j<m;j++)
{
b[k]=a[i][j];
k++;
}
else
for(j=m-1;j>=0;j--)
{
b[k]=a[i][j];
k++;
}
int sum=0;
for(i=1;i<n*m-1;i++)
{
int tag1=1,tag2=1;
for(j=0;j<n*m;j++)
if(b[j]<=b[i]&&j!=i)
tag1=0;
for(j=0;j<n*m;j++)
if(b[j]>=b[i]&&j!=i)
tag2=0;
if(tag1||tag2)
sum++;
}
printf("%d\n",sum);
}
return 0;
}