study in PTA(高精度算法与预处理)(2025.12.3)

7-11 GC学姐与大水仙花 - 25笨蛋队专属新生赛赛前模拟(补题)

1.这是我开始的代码

只有5分(满分20)

cpp 复制代码
#include <iostream>
#include <cmath>
using namespace std;

#define int long long

signed main()
{   int x;
    cin>>x;
    int sum=0;
    int cnt=0;

    int x1=x;
    while(x1)
        {x1/=10;
         cnt++;
        }

    int i=1;
    while(x)
        {int replace=x%10;
         sum+=pow(replace,i);
         i++;
         x/=10;
         //cout<<sum<<endl;
        }

    int result=sum%(1000000000+7);
    cout<<result;
    return 0;
}

后面一看数据

才知道(因为long long只有19位的数字,而这个数据是十万零一位数字,long long已经无法满足数据要求)

要用高精度算法,又为了避免运行超时所以使用了预处理

2.终极代码

cpp 复制代码
#include <iostream>
using namespace std;
#define int long long

int p[10][1000010]={0};
int m=1000000007;
string x;

signed main(){
    //预处理
    for(int i=0;i<10;i++)
    for(int j=0;j<=1000000;j++){
        if(j==0)p[i][j]=1;
        else{
            p[i][j]=p[i][j-1]*i%m;
        }
    }

    cin>>x;
    int digital=0;
    int ans=0;
    int j=1;
    for(int i=x.size()-1;i>=0;i--){//忘记是-了
        digital=x[i]-'0';
        ans+=p[digital][j++];
        ans%=m;//忘记取余了
    }
    cout<<ans;
    return 0;
}
相关推荐
NAGNIP6 小时前
万字长文!回归模型最全讲解!
算法·面试
知乎的哥廷根数学学派7 小时前
面向可信机械故障诊断的自适应置信度惩罚深度校准算法(Pytorch)
人工智能·pytorch·python·深度学习·算法·机器学习·矩阵
txinyu的博客7 小时前
解析业务层的key冲突问题
开发语言·c++·分布式
666HZ6668 小时前
数据结构2.0 线性表
c语言·数据结构·算法
SmartRadio8 小时前
ESP32添加修改蓝牙名称和获取蓝牙连接状态的AT命令-完整UART BLE服务功能后的完整`main.c`代码
c语言·开发语言·c++·esp32·ble
余瑜鱼鱼鱼9 小时前
Java数据结构:从入门到精通(十二)
数据结构
实心儿儿9 小时前
Linux —— 基础开发工具5
linux·运维·算法
charlie11451419110 小时前
嵌入式的现代C++教程——constexpr与设计技巧
开发语言·c++·笔记·单片机·学习·算法·嵌入式
清木铎11 小时前
leetcode_day4_筑基期_《绝境求生》
算法
清木铎11 小时前
leetcode_day10_筑基期_《绝境求生》
算法