大数运算(8)——大数幂运算

大数幂运算的实现有了前面的大数乘法算法做铺垫,就是调用乘法函数,来循环去自乘,幂指数相应减1,直到幂指数变为0时结束。

下面是C语言代码实现:

#include<stdio.h>
#include<string.h>
#define MAX 100
char str[MAX];
int pro[MAX*MAX];//位数分别为a,b的两个数相乘,其最大位数为a*b 
int num[MAX];
void mul(int num[],int pro[],int len)//乘法函数 
{
	int s[MAX*MAX]={0};//每次是s[MAX*MAX]里面的个元素为0 
	int i,j;
	for(i=0;i<len;i++)//将因数各个位上的数字与另一个各个位上的数字相乘 
	{
		for(j=0;j<MAX*MAX;j++)
			s[i+j]=s[i+j]+num[i]*pro[j];//先乘起来,后面统一进行进位			 
	}
	for(i=0;i<MAX*MAX;i++)//进行进位 
	{
		if(s[i]>=10)  //若>=10 
			s[i+1]=s[i+1]+s[i]/10;  //将十位上数字进位 
		pro[i]=s[i]%10;  //将个位上的数字留下
	}		
}
int main()
{
	int n;
	while(~scanf("%s %d",str,&n))
	{
		int i,j,k;
		int len=strlen(str);
		for(j=0,k=0,i=len-1;i>=0;i--)
		{
			num[j++]=str[i]-'0';
			pro[k++]=str[i]-'0';
		}			
		n--;//第一次是两个num[]相乘 
		while(n)//求幂运算 
		{
			mul(num,pro,len);
			n--;
		}
		for(i=MAX*MAX-1;i>0;i--)  //删除0的前缀 
		    if(pro[i])
			    break;
		for(;i>=0;i--)  //倒序输出 
			printf("%d",pro[i]);
		printf("\n");
	}
	return 0;
}




  • 3
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
OpenSAL1.1 包含了算法导论中所有数据结构和算法以及其他内容,本资源为该算法库的静态链接库 内容如下(*号表示1.1版本新增内容): 数据结构:一般堆、二项堆、斐波那契堆、红黑树、通用散列(采用全域散列和完全散列技术)、不相交集合、任意维数组、高维对称数组。 图论算法(兼容有向图,无向图):广度和深度优先遍历、确定图是否存在回路、拓扑排序、强连通分支、欧拉环(欧拉路径)、最小生成树(Kruskal、Prim)、单源最短路径(3种)、每对顶点间最短路径(2种)、最大流(2种)等等。 代数算法:霍纳法则计算多项式和、矩阵乘法(2种)、方阵的LUP分解、解线性方程组(2种)、矩阵求逆(2种)、求伪逆矩阵(2种)、解正态方程组(2种)、最小二乘估计(2种)、多元最小二乘估计*、快速傅里叶变换、快速傅里叶逆变换、多维快速傅里叶变换、多维快速傅里叶逆变换、快速向量求卷积(单变量多项式乘积)、快速张量求卷积(多变量多项式乘积)、多项式除法*、快速方幂和算法。 序列算法:最长公共子序列、KMP序列匹配*、键值分离排序。 数论算法:大数类(兼容浮点数、整数、与内置类型兼容运算)*、RSA加解密系统*、解同余方程*、孙子定理解同余方程组*、Miller_Rabin素数测试(产生大质数)*、随机数(实数、大数)*、欧几里得算法*。 计算几何算法:确定任意一对线段是否相交*、凸包*、最近点对*。 运筹学:线性规划(单纯形法)*、分配问题*、最优二度子图*、多01背包问题*

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值