I have written a small piece of code that would perform Run length encoding kind of stuff on 1-D array but still far from desired result.
main()
{
int a[8]={2,0,0,0,3,0,0,9};
int i,temp,ct=0,flag,m;
int found[90]={0};
for(i=0;i<=7;i++)
{
if(!a[i])
{
ct++;
if(!found[a[i]])
{
flag=i;
found[a[i]]=1;
}
}
}
a[flag]=ct;
m=ct;
for(i=0;i<m;i++)
{
printf("%d",a[i]);
}
}/* end of main*/
Now for above array i would like to have output something below
2 5 0 3 9
But with my piece of code am getting
2 5 0 0 3
Can I have any suggestion on that?
Shouldn’t run length encoding turn 2,0,0,0,3,0,0,9 into 2 1 0 3 3 1 2 0 9 1?
1) The first thing I see is wrong is that you aren’t looking at the entire array. You’re using < to stop before 8, but also stopping at 7, so you only evaluate array items 0 – 6.
2) If ct stands for count it’s never reset (ct=0 only on declaration). Also it’s assignment is this: a[flag]= ct; which overwrites your original data. It basically tracks the value of i.
This is my version I’ve just put together:
The output is
2 1 0 3 3 1 0 2 9 1Ok based on the comment left below, your algorithm would actually look like this:
which outputs:
2 5 0 3 9