#include <iostream>
#include <cmath>
#include <vector>
#include <string.h>
#include <bits/stdc++.h>
#include <cstdlib>
#include <time.h>
#include <fstream>
#include <iterator>
#include <utility>
#include <algorithm>
#include <set>
#include <map>
#include <bitset>
using namespace std;
#define ll long long
#define ull unsigned ll
#define ld long double
typedef vector<int> vi;
typedef multiset<int> mi;
typedef multiset<ll> mll;
typedef vector<ll> vll;
typedef vector<bool> vb;
typedef vector<string> vs;
typedef vector<vector<int>> _2vi;
typedef vector<vector<ll>> _2vll;
#define all(v) ((v).begin()), ((v).end())
#define sz(v) ((ll)((v).size()))
#define vinp(v, n) \
for (ull i = 0; i < (n); i++) \
cin >> (v)[i]
#define printv(v) \
for (auto i : (v)) \
cout << i << " "
#define fr0(i, n) for (ull(i) = 0; (i) < (n); (i)++)
#define fr1(i, n) for (ull(i) = 1; (i) < (n); (i)++)
#define fr(i, x, n) for (ull(i) = (x); (i) < (n); (i)++)
#define _CRT_SECURE_NO_WARNING
const ll MOD = 1000000007;
void Bustany()
{
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
#ifndef ONLINE_JUDGE
freopen("./in.txt", "r", stdin), freopen("./out.txt", "w", stdout);
#endif
}
void solve()
{
ll n;
cin >> n;
vector<ll> a(n);
vector<ll> b(n);
for (auto &i : a)
cin >> i;
for (auto &i : b)
cin >> i;
vll diff;
for (int i = 0; i < n; i++)
{
diff.push_back(a[i] - b[i]);
}
sort(all(diff));
ll l=0,r=n-1;
ll ans=0;
while(l<=r){
if(diff[l]+diff[r]>0){
ans+=r-l;
r--;
}
else{
l++;
}
}
cout << ans;
}
int main()
{
Bustany();
ll t = 1;
// cin >> t;
while (t--)
{
solve();
}
}
I2luY2x1ZGUgPGlvc3RyZWFtPgojaW5jbHVkZSA8Y21hdGg+CiNpbmNsdWRlIDx2ZWN0b3I+CiNpbmNsdWRlIDxzdHJpbmcuaD4KI2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNpbmNsdWRlIDxjc3RkbGliPgojaW5jbHVkZSA8dGltZS5oPgojaW5jbHVkZSA8ZnN0cmVhbT4KI2luY2x1ZGUgPGl0ZXJhdG9yPgojaW5jbHVkZSA8dXRpbGl0eT4KI2luY2x1ZGUgPGFsZ29yaXRobT4KI2luY2x1ZGUgPHNldD4KI2luY2x1ZGUgPG1hcD4KI2luY2x1ZGUgPGJpdHNldD4KCnVzaW5nIG5hbWVzcGFjZSBzdGQ7CgojZGVmaW5lIGxsIGxvbmcgbG9uZwojZGVmaW5lIHVsbCB1bnNpZ25lZCBsbAojZGVmaW5lIGxkIGxvbmcgZG91YmxlCnR5cGVkZWYgdmVjdG9yPGludD4gdmk7CnR5cGVkZWYgbXVsdGlzZXQ8aW50PiBtaTsKdHlwZWRlZiBtdWx0aXNldDxsbD4gbWxsOwp0eXBlZGVmIHZlY3RvcjxsbD4gdmxsOwp0eXBlZGVmIHZlY3Rvcjxib29sPiB2YjsKdHlwZWRlZiB2ZWN0b3I8c3RyaW5nPiB2czsKdHlwZWRlZiB2ZWN0b3I8dmVjdG9yPGludD4+IF8ydmk7CnR5cGVkZWYgdmVjdG9yPHZlY3RvcjxsbD4+IF8ydmxsOwojZGVmaW5lIGFsbCh2KSAoKHYpLmJlZ2luKCkpLCAoKHYpLmVuZCgpKQojZGVmaW5lIHN6KHYpICgobGwpKCh2KS5zaXplKCkpKQoKI2RlZmluZSB2aW5wKHYsIG4pICAgICAgICAgICAgICAgIFwKICAgIGZvciAodWxsIGkgPSAwOyBpIDwgKG4pOyBpKyspIFwKICAgIGNpbiA+PiAodilbaV0KI2RlZmluZSBwcmludHYodikgICAgICBcCiAgICBmb3IgKGF1dG8gaSA6ICh2KSkgXAogICAgY291dCA8PCBpIDw8ICIgIgojZGVmaW5lIGZyMChpLCBuKSBmb3IgKHVsbChpKSA9IDA7IChpKSA8IChuKTsgKGkpKyspCiNkZWZpbmUgZnIxKGksIG4pIGZvciAodWxsKGkpID0gMTsgKGkpIDwgKG4pOyAoaSkrKykKI2RlZmluZSBmcihpLCB4LCBuKSBmb3IgKHVsbChpKSA9ICh4KTsgKGkpIDwgKG4pOyAoaSkrKykKI2RlZmluZSBfQ1JUX1NFQ1VSRV9OT19XQVJOSU5HCmNvbnN0IGxsIE1PRCA9IDEwMDAwMDAwMDc7Cgp2b2lkIEJ1c3RhbnkoKQp7CiAgICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKGZhbHNlKTsKICAgIGNpbi50aWUoTlVMTCk7CiAgICBjb3V0LnRpZShOVUxMKTsKI2lmbmRlZiBPTkxJTkVfSlVER0UKICAgIGZyZW9wZW4oIi4vaW4udHh0IiwgInIiLCBzdGRpbiksIGZyZW9wZW4oIi4vb3V0LnR4dCIsICJ3Iiwgc3Rkb3V0KTsKI2VuZGlmCn0KCnZvaWQgc29sdmUoKQp7CiAgICBsbCBuOwogICAgY2luID4+IG47CiAgICB2ZWN0b3I8bGw+IGEobik7CiAgICB2ZWN0b3I8bGw+IGIobik7CiAgICBmb3IgKGF1dG8gJmkgOiBhKQogICAgICAgIGNpbiA+PiBpOwogICAgZm9yIChhdXRvICZpIDogYikKICAgICAgICBjaW4gPj4gaTsKICAgIHZsbCBkaWZmOwogICAgZm9yIChpbnQgaSA9IDA7IGkgPCBuOyBpKyspCiAgICB7CiAgICAgICAgZGlmZi5wdXNoX2JhY2soYVtpXSAtIGJbaV0pOwogICAgfQogICAgc29ydChhbGwoZGlmZikpOwogICAgbGwgbD0wLHI9bi0xOwogICAgbGwgYW5zPTA7CiAgICB3aGlsZShsPD1yKXsKICAgICAgICBpZihkaWZmW2xdK2RpZmZbcl0+MCl7CiAgICAgICAgICAgIGFucys9ci1sOwogICAgICAgICAgICByLS07CiAgICAgICAgfQogICAgICAgIGVsc2V7CiAgICAgICAgICAgIGwrKzsKICAgICAgICB9CiAgICB9CiAgICBjb3V0IDw8IGFuczsKfQoKaW50IG1haW4oKQp7CiAgICBCdXN0YW55KCk7CiAgICBsbCB0ID0gMTsKICAgIC8vICAgICBjaW4gPj4gdDsKICAgIHdoaWxlICh0LS0pCiAgICB7CiAgICAgICAgc29sdmUoKTsKICAgIH0KfQ==