《编程思维与实践》1062.计算2的N次方

news2024/11/26 0:46:00

《编程思维与实践》1062.计算2的N次方

题目

在这里插入图片描述

思路

法一:直接复用计算a的n次方的代码即可.

法二:注意到 2 30 2^{30} 230在int(32位,第一位为符号位, 2 31 − 1 2^{31}-1 2311)的范围内,可以直接处理.

注: int范围为 [ − 2 31 , 2 31 − 1 ] [-2^{31},2^{31}-1] [231,2311],大约为9位十进制整数; long long范围为 [ − 2 63 , 2 63 − 1 ] [-2^{63},2^{63}-1] [263,2631],大约为19位十进制整数.

unsigned int大约为10位十进制整数,unsigned long long大约为20位十进制整数.

代码

法一:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define N 11   

typedef struct{int cnt,v[N];}BIGINT;

BIGINT carry(BIGINT S,int bin)   //进位 bin表示进制 binary
{
	int flag=0;
	for(int i=0;i<S.cnt;i++)
	{
		int temp=S.v[i]+flag;
		S.v[i]=temp%bin;
		flag=temp/bin;
	}
	return S;
}

BIGINT int2BIG(int x,int bin)  //int 转换(to)成BIGINT 
{
    BIGINT R={0,{0}};
    do
    {
        R.v[R.cnt++]=x%bin;
        x/=bin;
    }while(x>0);
    return R;
}

BIGINT mul(BIGINT S, BIGINT T)     //两个大整数相乘
{
    BIGINT R={S.cnt+T.cnt,{0}};  //位数最多为两者相加
    for(int i=0;i<T.cnt;i++)
    {
        for (int j=0;j<S.cnt;j++)
        {
            R.v[i+j]+=S.v[j]*T.v[i];   //依此进行普通乘法
        }
    }
    R=carry(R,10);
    if(R.v[S.cnt+T.cnt-1]==0) 
	{
		R.cnt--; //最高位0不统计在一个大整数的位数中
	}
    return R;
}

BIGINT pow(BIGINT a, int n)  //计算 a的n次方
{
    BIGINT r;
    if(n==0)
	{
		return int2BIG(1,10);	
	}
    else if(n==1)
	{
		return a;	
	}
    r=pow(a, n/2);
    r=mul(r,r);
    if(n%2!=0)  //非偶数 需要多乘一个a 
	{
		r=mul(r, a);
	}
    return r;
}

int main()
{
	int T;
	scanf("%d",&T);
	for(int t=0;t<T;t++)
	{
		int n;
		scanf("%d",&n);
		printf("case #%d:\n",t);
		BIGINT ans=pow(int2BIG(2,10),n);
		for(int i=ans.cnt-1;i>=0;i--)
		{
			printf("%d",ans.v[i]);
		}
		printf("\n");
	}
    return 0;
}

法二:

#include<stdio.h>
#include<stdlib.h>
int main()
{
	int T;
	scanf("%d",&T);
	for(int t=0;t<T;t++)
	{
		int n;
		scanf("%d",&n);
		printf("case #%d:\n",t);
        int num=1;
		for(int i=0;i<n;i++)
		{
			num*=2;
		}
		printf("%d\n",num);
	}
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/513734.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

利用Eigen求解不同坐标系的旋转矩阵

不同坐标系之间的刚性转换以及实现&#xff1a; 坐标系转换原理如下&#xff0c;使用了仿射变换实现了旋转平移&#xff1a; [ r 11 r 12 t x r 21 r 22 t y 0 0 ] ∗ [ x y 1 ] [ x ′ y ′ 1 ] \begin{bmatrix} r_{11} & r_{12}& t_x\\ r_{21}& r_{22}& t…

有没有免费的云渲染平台?

有没有免费的云渲染平台&#xff1f;相信很多人在找云渲染平台的时候都会先网上查找下有没有免费的平台可以使用&#xff0c;而且也确实看到很多云渲染平台写着“免费渲染”&#xff0c;所以这免费是真的免费还是只是一个噱头呢&#xff1f;下面&#xff0c;由前沿的 云渲染平台…

如何应对洗钱犯罪的新变化?探索图数据库在反洗钱中的应用

背景导读 洗钱&#xff0c;即对非法资金的合法化过程。它由违法犯罪集团组织&#xff0c;在躲避银行和执法部门监测情况下&#xff0c;利用违法交易手段对非法收益进行转移&#xff0c;是金融犯罪领域最难发现的活动之一。当前&#xff0c;洗钱团伙日趋集团化、规模化和专业化…

服务熔断Hystrix入门

目录 一. 微服务的核心知识1.1 雪崩效应1.2 服务隔离1.3 熔断降级1.4 服务限流 二. Hystrix介绍三. Hystrix服务熔断的实现方式3.1 Rest 实现熔断3.2 Feign实现服务熔断 四.服务熔断Hystrix高级4.1 Hystrix的监控平台4.2 搭建Hystrix DashBoard监控4.2.1 熔断器的状态4.2.1.1 测…

成为一名高级网络安全工程师,你需要学习什么?

前言 这是我的建议如何成为网络安全工程师&#xff0c;你应该按照下面顺序学习。 简要说明 第一件事你应该学习如何编程&#xff0c;我建议首先学python&#xff0c;然后是java。 &#xff08;非必须&#xff09;接下来学习一些算法和数据结构是很有帮助的&#xff0c;它将帮…

ChatGpt vs 文心一言,谁更厉害

前言 ​ 当下最火的人工智能毫无疑问是大模型的聊天机器人&#xff0c;ChatGpt的出现&#xff0c;让无数人为之惊叹&#xff0c;它聪明、逻辑清晰、又什么都懂&#xff0c;甚至被人们认为是第四次工业革命的开端。AI的大模型之争&#xff0c;美国的OpenAI已经率先拔得头筹&…

Path如何进行环境变量的配置?

开发Java程序&#xff0c;需要使用JDK提供的开发工具(比如javac.exe、java.exe等命令)&#xff0c;而这些工具在JDK的安装目录的 bin目录下&#xff0c;如果不配置环境变量&#xff0c;那么这些命令只可以在该目录下执行。我们不可能把所有的java文件都放到JDK 的bin目录下&…

笛卡尔坐标系和Frenet坐标系

笛卡尔坐标系和Frenet坐标系 Frenet坐标系&#xff0c;自动驾驶“混乱”的源头 【自动驾驶】运动规划丨轨迹规划丨Frenet坐标转换 【自动驾驶】笛卡尔坐标系和frenet坐标系相互转换 轨迹规划作为具有多个非线性约束的高维优化问题&#xff0c;需要消耗大量的计算资源&#xff0…

前端012_标签模块_条件查询实现

标签模块_条件查询实现 1、需求分析2、Mock添加分类数据3、Api调用分类接口4、添加条件查询模版1、需求分析 在列表上方添加通过标签名称、分类名称的查询功能。 Form 表单参考 :https://element.eleme.cn/#/zh-CN/component/form#xing-nei-biao-danSelect选择器:https://el…

4-表约束和表设计

目录 1.表约束 1.1.什么是表约束&#xff1f; 1.2.为什么需要表约束&#xff1f; 1.3.常见的表约束 1.3.1.非空约束 not null --->a.查看非空约束 --->b.验证非空约束 1.3.2.唯一约束 unique --->a.查看唯一约束 --->b.验证唯一约束 --->PS&#xff…

error处理:org.springframework.web.bind.MissingServletRequestParameterException

在工作中遇到错误org.springframework.web.bind.MissingServletRequestParameterException 此时为POST方法&#xff0c;添加了RequestParam注解&#xff0c;如图 postman中请求如下 解决办法:选择form-data进行传参即可

linux 设备树详解

设备树 描述设备树的文件叫做 DTS(Device Tree Source)&#xff0c;这个 DTS 文件采用树形结构描述板级设备&#xff0c;也就是开发板上的设备信息&#xff0c;比如CPU 数量、 内存基地址、IIC 接口上接了哪些设备、SPI 接口上接了哪些设备等等。 树的主干就是系统总线&#x…

【服务器数据恢复】Linux系统下OA+oracle的数据恢复案例

服务器数据恢复环境&#xff1a; 某公司一台服务器中组建一组raid5磁盘阵列&#xff1b; 上层操作系统为linux redhat&#xff0c;部署OA系统&#xff0c;后端数据库为oracle。 服务器故障&初检&#xff1a; raid5中有2块磁盘先后掉线&#xff0c;服务器崩溃。oracle已经不…

springboot使用ECharts、ECharts html中文乱码、直接引用CDN资源文件和引用本地资源文件哪个好

springboot使用ECharts、动态地引用版本 1.添加依赖2.创建图表引入ECharts文件方式直接引用CDN资源文件和引用本地资源文件哪个好 3.映射4.添加配置加载ECharts资源5.测试访问6.升级版本号问题7.ECharts html中文乱码 如果想在Spring Boot应用程序中使用ECharts&#xff0c;则可…

多目标检测:基于Yolo优化的多目标检测(附论文下载)

关注并星标 从此不迷路 计算机视觉研究院 公众号ID&#xff5c;ComputerVisionGzq 学习群&#xff5c;扫码在主页获取加入方式 计算机视觉研究院专栏 作者&#xff1a;Edison_G 为了解决目标检测任务中小目标检测精度低、误检、漏检率高等问题&#xff0c;有研究者提出了一种新…

前端实战项目:网易云静态页面——主页面右侧部分

文章目录 前言main部分结构布局用户登陆右侧列表header的封装歌手列表主播列表申请按钮 总代码 前言 项目持续更新中&#xff5e; 网易云静态页面——导航栏 网易云静态页面——轮播图 Flex布局详解 所用到文件及文件夹 header&#xff1a;是对某些标题样式的封装 main&…

软考A计划-重点考点-专题十一(系统工程知识)

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例 &#x1f449;关于作者 专注于Android/Unity和各种游戏开发技巧&#xff0c;以及各种资源分享&am…

2023蓝桥杯真题c++省A

[蓝桥杯 2023 省 A] 填空问题 比赛的时候&#xff0c;脑袋要清晰一点&#xff0c;当时写 幸运数 这道题都感觉没在用脑子思考&#xff0c;花了特别多时间 A. 幸运数 小蓝认为如果一个数含有偶数个数位&#xff0c;并且前面一半的数位之和等于后面一半的数位之和&#xff0c;…

小家电类产品出口欧美国家/亚马逊平台认证要求请知悉!

小家电类产品CE认证 欧盟&#xff1a; “CE”标志是一种安全认证标志&#xff0c;被视为制造商打开并进入欧洲市场的护照。CE代表欧洲统一&#xff08;CONFORMITE EUROPEENNE&#xff09;。 根据欧盟的法律&#xff0c;生产商和进口商负责验证其产品符合相关的欧盟指令的要求…

哪款洗地机适合家用?家用洗地机型号分享

洗地机采用多种清洁方式&#xff0c;如湿拖、干拖、热水清洗等&#xff0c;可针对不同使用场合和地面类型进行清洁。而且洗地机无需手工操作&#xff0c;智能感应地面脏污&#xff0c;自动适应地面清洁程度&#xff0c;保证了清洁效率和效果。本文将为大家推荐几款性价比较高、…