zoukankan      html  css  js  c++  java
  • 前n项和!

    就当是练习了(各种高精度)!综合很强!

    View Code
    #include"iostream"
    #define M 1010
    using namespace std;
    char ch1[M],ch2[M];
    int a[M],b[M];
    int c[M],d[M];
    int num[M];
    int sum[M];
    int W[M];
    int H[M];
    int t,k,g,v;
    int i,j;
    int La,Lb;
    int sign=0;
    int s;
    int L;
    void _ADD()
    {
    La
    =0;
    W[La
    ++]=(sum[L-1]+1)%10;
    int flag=(sum[L-1]+1)/10;

    int i;

    for(i=L-2;i>=0;i--)
    {
    W[La
    ++]=(sum[i]+flag)%10;
    flag
    =(sum[i]+flag)/10;
    }
    while(flag)
    {
    W[La
    ++]=flag%10;
    flag
    /=10;
    }
    }

    void Div( int *xx)
    {
    Lb
    =0;
    int sign=0;
    for(int i=0;i<L;i++)
    {
    if((xx[i]+sign)>=2)
    {
    b[Lb
    ++]=(xx[i]+sign)/2;
    sign
    =(xx[i]-2*(xx[i]/2));
    }
    else
    {
    sign
    =xx[i]*10;
    if(i) b[Lb++]=0;
    }
    }
    }

    void Add(int x ,int y)
    {
    sign
    =0; t=0;
    int p,q,flag=0;
    if(x>y)
    {
    for(p=0,q=0;p<y,q<y; p++,q++)
    {
    num[t
    ++]=(d[p]+H[q]+flag)%10;
    flag
    =(d[p]+H[q]+flag)%10;
    }
    for(p=y; p<x ; p++)
    {
    num[t
    ++]=(d[p]+flag)%10;
    flag
    =(d[p]+flag)/10;
    }
    }
    else if(x==y)
    {
    for(p=0,q=0;p<x,q<y; p++,q++)
    {
    num[t
    ++]=(d[p]+H[q]+flag)%10;
    flag
    =(d[p]+H[q]+flag)/10;
    }
    }

    else
    {
    flag
    =0;
    for(p=0,q=0;p<x,q<x; p++,q++)
    {
    num[t
    ++]=(H[p]+d[q]+flag)%10;
    flag
    =(H[p]+d[q]+flag)/10;
    }
    for(q=x;q<y;q++)
    {
    num[t
    ++]=(H[q]+flag)%10;
    flag
    =(H[q]+flag)/10;
    }
    }
    while(flag)
    {
    num[t
    ++]=flag%10;
    flag
    /=10;
    }

    for(int yy=0; yy<t;yy++)
    {
    d[yy]
    =num[yy];
    if(d[yy]==0) sign++; //sign用于标记结果为0的情况
    }
    g
    =t;
    memset(H ,
    0 , sizeof(H));
    memset(num,
    0, sizeof(num));
    }

    void BigN()
    {
    int flag=0;
    int mark=0;
    if(La>Lb)
    {
    for(i=Lb-1;i>=0;i--)
    {
    k
    =0;
    for(j=La-1;j>=0;j--)
    {
    c[k
    ++]=(b[i]*a[j]+flag)%10;
    flag
    =(b[i]*a[j]+flag)/10;
    }

    while(flag)
    {
    c[k
    ++]=flag%10;
    flag
    /=10;
    }

    //末尾赋值0
    v=0;
    for(int xx=0; xx<mark; xx++)
    H[v
    ++]=0;
    for(int m=0;m<k;m++)
    H[v
    ++]=c[m];

    memset(c,
    0,sizeof(c));
    Add(g , v);
    mark
    ++;
    }
    }
    else
    {
    for(i=La-1;i>=0;i--)
    {
    k
    =0;
    for(j=Lb-1;j>=0;j--)
    {
    c[k
    ++]=(a[i]*b[j]+flag)%10;
    flag
    =(a[i]*b[j]+flag)/10;
    }
    while(flag)
    {
    c[k
    ++]=flag%10;
    flag
    /=10;
    }

    //末尾赋值0
    v=0;
    for(int xx=0; xx<mark; xx++)
    H[v
    ++]=0;
    for(int m=0;m<k;m++)
    H[v
    ++]=c[m];
    Add(g , v);
    mark
    ++;
    }
    }
    }
    int main()
    {
    while(cin>>ch1)
    {
    t
    =0;k=0;g=0;

    L
    =strlen(ch1);
    for(i=0;i<L;i++) { sum[i]=ch1[i]-'0';}
    _ADD();

    if(W[La-1]%2==0)
    {
    for(i=0;i<L;i++) a[i]=ch1[i]-'0';
    L
    =La; Div(W);
    }
    else
    {
    for(i=0;i<La;i++) a[i]=W[i];
    Div(sum);
    }
    BigN();

    if(sign!=t)
    {
    for(i=t-1;i>=0;i--)
    cout
    <<d[i];
    cout
    <<endl;
    }
    else cout<<"0"<<endl;
    }
    return 0;
    }
  • 相关阅读:
    android so壳入口浅析
    PySide图形界面开发(一)
    对一个伪装成微信的加固病毒的分析
    ZjDroid工具介绍及脱壳详细示例
    用pyinstaller把python代码打包成exe可执行文件
    Android下so注入汇总
    利用drozer进行Android渗透测试
    OWASP移动安全漏洞Top 10
    python with原理
    腾讯云
  • 原文地址:https://www.cnblogs.com/FCWORLD/p/2034567.html
Copyright © 2011-2022 走看看