sdut2165 Crack Mathmen (山东省第二届ACM省赛)

本文出自:http://blog.csdn.net/svitter,转载请注明出处。

原题:点击打开链接


晨阳哥一同讨论了一下这个题目= =终于在今晚AC了。

这个题目可以说是RSA加密算法的变种。。

考虑997是素数,那么符合欧拉定理,然后想到费马小定理 m ^ 996 MOD 997 = 1;

因为一般的RSA解密算法都是C^d mod 997 = m 这种形式,苦思冥想了好久解密算法,仍然没有得到解决。

最后终于大彻大悟的明白:

呵呵,你想多了。。这个题目可以用打表过- -

要注意的问题:

1.加密码与原码是要一一对应,在原码中已经标出。

2.计算MOD幂的时候使用二分算法,如果不使用必然超时(n 可以取到  10 ^ 9)。这个算法依据pow算法得出。

/*author : Vit/csdn   
 *from: http://blog.csdn.net/svitter  
 *if you love it, please show the original site*/  


#include <iostream>
#include <stdio.h>
#include <string.h>

using namespace std;

#define lln long long int

char str[1000010];
char key[1001];
lln ch[127];
lln n;
lln ans, tt, temp;

bool get(lln &c)
{
    temp = c, ans = 1, tt = n;
    while(tt)
    {
        if(tt &1)
            ans = (ans * temp) % 997;
        temp = temp * temp % 997;
        tt = tt >> 1;
    }
    if(ch[c] == -1)
        ch[c] = ans;
}

bool init()
{
    lln i;
    memset(ch, -1, sizeof(ch));
    memset(key, '\0', sizeof(key));
    for(i = 32; i < 127; i++)
    {
        if(get(i))
            continue;
        else
            return false;
    }

    for(i = 32; i < 127; i++)
    {
        lln &tmp = ch[i];
        if(key[tmp] == '\0')//检查码值相同的情况
            key[ch[i]] = (char)i;
        else
        {
            return false;
        }
    }
    return true;
}

void ace()
{
    lln c, cur;
    lln length;
    lln i, l;
    char temp[400000];
    bool isstr;
    cin >> c;
    while(c--)
    {
        while(cin >> n)
        {
            memset(str, '\0', sizeof(str));
            scanf("%s", str);
            if(init())
            {
                l = 0;
                isstr = 1;
                //cout << key[590] << endl;
                length = strlen(str);
                for(i = 0; i < length; i += 3)
                {
                    cur = (str[i]-'0') *100 + (str[i+1]-'0') * 10 + str[i+2] - '0';
                    if(key[cur] != '\0')//没有对应的翻译码
                        temp[l++] = key[cur];
                    else
                    {
                        isstr = false;
                        break;
                    }
                }
                if(isstr)
                {
                    for(i = 0; i < l; i++)
                        cout << temp[i];
                    cout << endl;
                }
                else
                {
                    cout << "No Solution" << endl;
                }
            }
            else
            {
                cout << "No Solution" << endl;
            }
        }
    }
}

int main()
{
    ace();
    return 0;
}




转载于:https://my.oschina.net/u/1017188/blog/333496

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
毕业设计,基于SpringBoot+Vue+MySQL开发的纺织品企业财务管理系统,源码+数据库+毕业论文+视频演示 在如今社会上,关于信息上面的处理,没有任何一个企业或者个人会忽视,如何让信息急速传递,并且归档储存查询,采用之前的纸张记录模式已经不符合当前使用要求了。所以,对纺织品企业财务信息管理的提升,也为了对纺织品企业财务信息进行更好的维护,纺织品企业财务管理系统的出现就变得水到渠成不可缺少。通过对纺织品企业财务管理系统的开发,不仅仅可以学以致用,让学到的知识变成成果出现,也强化了知识记忆,扩大了知识储备,是提升自我的一种很好的方法。通过具体的开发,对整个软件开发的过程熟练掌握,不论是前期的设计,还是后续的编码测试,都有了很深刻的认知。 纺织品企业财务管理系统通过MySQL数据库与Spring Boot框架进行开发,纺织品企业财务管理系统能够实现对财务人员,员工,收费信息,支出信息,薪资信息,留言信息,报销信息等信息的管理。 通过纺织品企业财务管理系统对相关信息的处理,让信息处理变的更加的系统,更加的规范,这是一个必然的结果。已经处理好的信息,不管是用来查找,还是分析,在效率上都会成倍的提高,让计算机变得更加符合生产需要,变成人们不可缺少的一种信息处理工具,实现了绿色办公,节省社会资源,为环境保护也做了力所能及的贡献。 关键字:纺织品企业财务管理系统,薪资信息,报销信息;SpringBoot
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值