这个代码有一点点没有看懂 想知道怎么解释捏

P1134 [USACO3.2]阶乘问题 - 洛谷 | 计算机科学教育新生态 https://www.luogu.com.cn/problem/P1134


#include<bits/stdc++.h>
using namespace std;

long long n,now=1,mod = 10000000;

int main(){
    cin>>n;
    for(long long i=1;i<=n;i++){
        now = now*i;
        while(now%10==0)now = now/10;
        now = now%mod;//这里整除1000000是什么意思捏 
    }
    cout<<now%10<<endl;//输出的时候怎么又要%10捏 

}


 
#include<bits/stdc++.h>
using namespace std;
 
long long n,now=1,mod = 10000000;
 
int main(){
    cin>>n;
    for(long long i=1;i<=n;i++){//每次循环都走一遍下面流程
        now = now*i;//目前阶乘总值,例如 算出这个数-------------->98765432100000
        while(now%10==0)now = now/10;//这个循环去掉总值后面的所有0------>987654321
        now = now%mod;//只取去掉0的now的后七位----------->7654321
    }
    cout<<now%10<<endl;//将该七位数取最后一位(假设最后一次循环now为7654321-------------->1)
}