SGU112
题意:求a^b-b^a次,100以内。大数的-和*的模拟,用的模板,注意该模板中间和结果都不能出现负数。
#include<iostream>
#include<string>
using namespace std;
const int ten[4]={1,10,100,1000};
const int maxl=1000;
struct bignum
{
int d[maxl];
bignum(string s)
{
int len=s.size();
d[0]=(len-1)/4+1;
int i,j,k;
for(i=1;i<maxl;i++)d[i]=0;
for(i=len-1;i>=0;i--)
{
j=(len-i-1)/4+1;
k=(len-i-1)%4;
d[j]+=ten[k]*(s[i]-'0');
}
while(d[0]>1&&d[d[0]]==0)--d[0];
}
bignum()
{
*this=bignum(string("0"));
}
string tostring()
{
string s("");
int i,j,temp;
for(i=3;i>=1;i--)if(d[d[0]]>=ten[i])break;
temp=d[d[0]];
for(j=i;j>=0;j--)
{
s=s+(char)(temp/ten[j]+'0');
temp%=ten[j];
}
for(i=d[0]-1;i>0;i--)
{
temp=d[i];
for(j=3;j>=0;--j)
{
s=s+(char)(temp/ten[j]+'0');
temp%=ten[j];
}
}
return s;
}
}zero("0"),d,temp,mid1[20];
bool operator < (const bignum &a ,const bignum &b)
{
if(a.d[0]!=b.d[0])return a.d[0]<b.d[0];
int i;
for(i=a.d[0];i>0;i--)if(a.d[i]!=b.d[i])return a.d[i]<b.d[i];
return 0;
}
bignum operator - (const bignum &a ,const bignum &b)
{
bignum c;
c.d[0]=a.d[0];
int i,x=0;
for(i=1;i<=c.d[0];i++)
{
x=10000+a.d[i]-b.d[i]+x;
c.d[i]=x%10000;
x=x/10000-1;
}
while((c.d[0]>1)&&(c.d[c.d[0]]==0))--c.d[0];
return c;
}
bignum operator *(const bignum &a,const bignum &b)
{
bignum c;
c.d[0]=a.d[0]+b.d[0];
int i,j,x;
for(i=1;i<=a.d[0];i++)
{
x=0;
for(j=1;j<=b.d[0];j++)
{
x=a.d[i]*b.d[j]+x+c.d[i+j-1];
c.d[i+j-1]=x%10000;
x/=10000;
}
c.d[i+b.d[0]]=x;
}
while((c.d[0]>1)&&(c.d[c.d[0]]==0))--c.d[0];
return c;
}
string getstring(int a)
{
string ss;
while(a!=0)
{
ss= char('0'+(a%10))+ss;
a/=10;
}
return ss;
}
int main()
{ int aa,bb;
cin>>aa>>bb;
if(aa==bb)
{
cout<<0<<endl;
return 0;
}
string ta=getstring(aa),tb=getstring(bb);
bignum a(ta); bignum b(tb);
// cout<<a.tostring();
// cout<<b.tostring()<<endl;
bignum ans1("1"),ans2("1"); for(int i=0;i<bb;i++)
{
ans1=ans1*a;
}
// cout<<ans1.tostring()<<endl;
for(int i=0;i<aa;i++)
{
ans2=ans2*b;
}
// cout<<ans2.tostring()<<endl;
if(ans2<ans1)
{
bignum ans=ans1-ans2;
cout<<ans.tostring()<<endl;
}
else
{
bignum ans=ans2-ans1;
cout<<"-"<<ans.tostring()<<endl;
}
return 0;
}
SGU112的更多相关文章
- SGU Volume 1
SGU 解题报告(持续更新中...Ctrl+A可看题目类型): SGU101.Domino(多米诺骨牌)------------★★★type:图 SGU102.Coprimes(互质的数) SGU1 ...
- 今日SGU 5.2
SGU123 题意:求和 收获:无 #include<bits/stdc++.h> #define de(x) cout<<#x<<"="< ...
随机推荐
- LeetCode || 递归 / 回溯
呜呜呜 递归好不想写qwq 求“所有情况”这种就递归 17. Letter Combinations of a Phone Number 题意:在九宫格上按数字,输出所有可能的字母组合 Input: ...
- 实验十一 团队作业7:团队项目设计完善&编码
实验十一 团队作业7:团队项目设计完善&编码 实验时间 2019-6-6 Deadline: 2019-6-12 10:00,以团队随笔博文提交至班级博客的时间为准. 评分标准: 按时交 – ...
- javascript基础知识 (八) BOM学习笔记
一.什么是BOM BOM(Browser Object Model)即浏览器对象模型. BOM提供了独立于内容 而与浏览器窗口进行交互的对象: 由于BOM主要用于管理窗口 ...
- CF815D Karen and Cards 官方题解翻译
看到这道题,网上没有中文版的官方题解,于是就自己翻译了一遍. 不是机器翻译,是一个字一个字纯手翻译的,如果有错误欢迎指正. 比如我们有一张卡片,三个参数分别是 a1 = 4, b1 = 2, c1 = ...
- 初涉平衡树「treap」
treap:一种平衡的二叉搜索树 什么是treap(带旋) treap=tree+heap,这大家都知道.因为二叉搜索树(BST)非常容易被卡成一条链而影响效率,所以我们需要一种更加平衡的树形结构,从 ...
- 常用模块之configpaser与shutil
configparser模块 定义:configparser翻译为配置解析,即它是用来解析配置文件的 配置文件:用于编写程序的配置信息的文件 配置文件编写格式 配置文件中只允许出现两种类型的数据 se ...
- 递归函数&二分查找
一.递归函数 1)定义 在函数中调用函数本身,就是递归 在python中递归的深度最大为1000,但实际达不到1000 def func(): print("-----func-----&q ...
- java 之Thread线程相关yield()、sleep()、wait()、join()、run和start方法详解
1.sleep() 使当前线程(即调用该方法的线程)暂停执行一段时间,让其他线程有机会继续执行,但它并不释放对象锁.也就是说如果有synchronized同步快,其他线程仍然不能访问共享数据.注意该方 ...
- Objective-C 正则表达式使用(1)
学习了一下OC的正则表达式备忘一下 使用正则表达式的步骤: 创建一个一个正则表达式对象:定义规则. 利用正则表达式对象测试,相应的字符串. NSString *userName = @"12 ...
- shell基础学习-难点重点学习
来自shell13问 -e : 啟用反斜線控制字符的轉換(參考下表) -E:關閉反斜線控制字符的轉換(預設如此) -n : 取消行末之換行符號(與 -e 選項下的 \c 字符同意) 要取消一個变量,在 ...