#include <algorithm>
#include <iostream>
#include <iterator>
#include <string>
#include <unordered_map>
#include<vector>
using namespace std;
int main() {
int n;
cin>>n;
std::string str;
cin>>str;
std::unordered_map<char, vector<int>> charindices;
for(int i=0;i<n;i++){
charindices[str[i]].push_back(i);//将每个不同字符的索引保留
}
long long res=0;
for(int i=0;i<n;i++){
char a=str[i];
for(auto& [b,indice]:charindices){
if(a==b) continue;
auto it=upper_bound(indice.begin(),indice.end(), i);//找出大于索引a的位置
int cnt=distance(it, indice.end());
if(cnt>=2){
res+=cnt*(cnt-1)/2;
}
}
}
cout<<res;
return 0;
}
// 64 位输出请用 printf("%lld")