#include <bits/stdc++.h>
using namespace std;
#define int long long
#define dd double
#define ld long double
#define ull unsigned long long
#define yes cout << "YES\n"
#define no cout << "NO\n"
#define el "\n"
#define Arwa ios::sync_with_stdio(0); cin.tie(0); cout.tie(0);
#define fix(x) cout << fixed << setprecision(x)
#define all(v) v.begin(),v.end()
#define dpp(v,val) memset(v,val,sizeof(v))
#define mod 1e9+7
#define oo 1e9
const int N = 1e5 + 5;
int n;
vector<int>v;
int dp[102][4];
int solve(int i,int j)
{
if(i==n) return 0;
int& ret=dp[i][j];
if(ret!=-1) return ret;
int l=solve(i+1,j),t=0;
if(j==0)
{
if(v[i]==0) t=solve(i+1,v[i]);
else if(v[i]==3) t=max(solve(i+1,2),solve(i+1,1))+1;
else t=solve(i+1,v[i])+1;
}
if(j==1)
{
if(v[i]==0) t=solve(i+1,v[i]);
else if(v[i]==3||v[i]==2) t=solve(i+1,2)+1;
}
if(j==2)
{
if(v[i]==0) t=solve(i+1,v[i]);
else if(v[i]==3||v[i]==1) t=solve(i+1,1)+1;
}
return ret=max(t,l);
}
void HereWeGoAgain()
{
cin>>n;
v.resize(n);
for(int i=0;i<n;i++) cin>>v[i];
dpp(dp,-1);
cout<<n-solve(0,0);
}
int32_t main()
{
Arwa
int t=1;
//cin>>t;
for(int i=1;i<=t;i++)
{
HereWeGoAgain();
}
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CiNkZWZpbmUgaW50IGxvbmcgbG9uZwojZGVmaW5lIGRkIGRvdWJsZQojZGVmaW5lIGxkIGxvbmcgZG91YmxlCiNkZWZpbmUgdWxsIHVuc2lnbmVkIGxvbmcgbG9uZwojZGVmaW5lIHllcyBjb3V0IDw8ICJZRVNcbiIKI2RlZmluZSBubyBjb3V0IDw8ICJOT1xuIgojZGVmaW5lIGVsICJcbiIKI2RlZmluZSBBcndhIGlvczo6c3luY193aXRoX3N0ZGlvKDApOyBjaW4udGllKDApOyBjb3V0LnRpZSgwKTsKI2RlZmluZSBmaXgoeCkgY291dCA8PCBmaXhlZCA8PCBzZXRwcmVjaXNpb24oeCkKI2RlZmluZSBhbGwodikgdi5iZWdpbigpLHYuZW5kKCkKI2RlZmluZSBkcHAodix2YWwpIG1lbXNldCh2LHZhbCxzaXplb2YodikpCiNkZWZpbmUgbW9kIDFlOSs3CiNkZWZpbmUgb28gMWU5CmNvbnN0IGludCBOID0gMWU1ICsgNTsKaW50IG47CnZlY3RvcjxpbnQ+djsKaW50IGRwWzEwMl1bNF07CmludCBzb2x2ZShpbnQgaSxpbnQgaikgCnsKICBpZihpPT1uKSByZXR1cm4gMDsKICBpbnQmIHJldD1kcFtpXVtqXTsKICBpZihyZXQhPS0xKSByZXR1cm4gcmV0OwogIGludCBsPXNvbHZlKGkrMSxqKSx0PTA7CiAgaWYoaj09MCkKICB7CiAgICBpZih2W2ldPT0wKSB0PXNvbHZlKGkrMSx2W2ldKTsKICAgIGVsc2UgaWYodltpXT09MykgdD1tYXgoc29sdmUoaSsxLDIpLHNvbHZlKGkrMSwxKSkrMTsKICAgIGVsc2UgdD1zb2x2ZShpKzEsdltpXSkrMTsKICB9CgogIGlmKGo9PTEpCiAgewogICAgaWYodltpXT09MCkgdD1zb2x2ZShpKzEsdltpXSk7CiAgICBlbHNlIGlmKHZbaV09PTN8fHZbaV09PTIpIHQ9c29sdmUoaSsxLDIpKzE7CiAgfQoKICBpZihqPT0yKQogIHsKICAgIGlmKHZbaV09PTApIHQ9c29sdmUoaSsxLHZbaV0pOwogICAgZWxzZSBpZih2W2ldPT0zfHx2W2ldPT0xKSB0PXNvbHZlKGkrMSwxKSsxOwogIH0KICByZXR1cm4gcmV0PW1heCh0LGwpOwp9CnZvaWQgSGVyZVdlR29BZ2FpbigpCnsKICBjaW4+Pm47CiAgdi5yZXNpemUobik7CiAgZm9yKGludCBpPTA7aTxuO2krKykgY2luPj52W2ldOwogIGRwcChkcCwtMSk7CiAgY291dDw8bi1zb2x2ZSgwLDApOwp9CmludDMyX3QgbWFpbigpIAp7CiAgICBBcndhCiAgICBpbnQgdD0xOwogICAgLy9jaW4+PnQ7CiAgICBmb3IoaW50IGk9MTtpPD10O2krKykKICAgIHsKICAgIEhlcmVXZUdvQWdhaW4oKTsKICAgIH0KICAgIHJldHVybiAwOwp9