这题提供两种做法:1:数学公式推到做法 2:优雅暴力做法
核心思路:本题转化为:(i从1枚举到n,求i是1到n个多少个数的约数)
(ps:两种做法都是基于上面的核心思路来展开)
1:数学做法:
cin>>n;
for(int i=1;i<=n;i++)ans+=n/i;
cout<<ans;
2:优雅暴力做法:
int prime() {
int res=0;
for(int i=1; i<=n; i++) {//枚举约数
for(int j=i; j<=n; j+=i) {//j+=i,那i肯定是j的约数
a[j]++;//j的约数+1
}
res+=a[i];//+=当前i的约数
}
return res;
}
okk上:
ACcode:(筛法)
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=1e6+10;
//本题转化为求(i从1枚举到n,求i是1到n个数中的约数)
int n,a[N];
int prime() {
int res=0;
for(int i=1; i<=n; i++) {//枚举约数
for(int j=i; j<=n; j+=i) {//j+=i,那i肯定是j的约数
a[j]++;//j的约数+1
}
res+=a[i];//+=当前i的约数
}
return res;
}
void solve() {
cin>>n;
cout<<prime()<<"\n";
}
int main() {
ios::sync_with_stdio(false);
solve();
return 0;
}
over~~