IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 幂方分解(c语言 内存超级小) -> 正文阅读

[C++知识库]幂方分解(c语言 内存超级小)

问题描述

????????任何一个正整数都可以用2的幂次方表示。例如:

????????137=2^7+2^3+2^0

????????同时约定方次用括号来表示,即a^b可表示为a(b)。

????????由此可知,137可表示为:

????????2(7)+2(3)+2(0)

????????进一步:7=2^2+2+2^0(2的1次方用2表示)

????????3=2+2^0

????????所以最后137可表示为:

????????2(2(2)+2+2(0))+2(2+2(0))+2(0)

????????又如;

????????1315=2^10+2^8+2^5+2+1

????????所以1315最后可表示为:

? ? ? ? 2(2(2+2(0))+2)+2(2(2+2(0)))+2(2(2)+2(0))+2+2(0)

【输入格式】

? ? ? ? 输入包含一个正整数N(N<=20000),为要求分解的整数。

【输出格式】

? ? ? ? 程序输出包含一行字符串,为符合约定的n的0,2表示(在表示中不能有空格)

【分析】

? ? ? ? 该题使用递归做。

? ? ? ? 最大数为2^14<20000<2^15

? ? ? ? 2^3<14<2^4

? ? ? ? 2^1<3<2^2

? ? ? ? 可知最多需要三次递归。

【代码】

? ? ? ?

#include<stdio.h>
void digui2(int j){        //第三次递归,目的是分解二维幂次
		int i=0,n=1;
	for(;n<=j;i++){
		n*=2;
	}
	i--;        //标记三维幂次
	printf("2");
	if(i==0){
		printf("(%d)",i);
		}
	if((j-=(n/2))!=0){        //符合第三次递归,二维幂次没有完全被表示
		printf("+");
		digui2(j);
	}
}
void digui1(int j){        //第二次递归,递归的是一维幂次
	int i=0,n=1;
	for(;n<=j;i++){
		n*=2;
	}
	i--;        //标记二维幂次
	printf("2");
	if(i==0){
		printf("(%d)",i);
		}
		if(i>1){        //符合第三次递归
		printf("(");
		digui2(i);
		printf(")");
	}
	if((j-=(n/2))!=0){        //符合第二次递归,第一维幂次还没有被完全表示
		printf("+");
		digui1(j);
	}
}
void digui(int N){        //第一次递归,递归的是N=n1+n2+……
	int i=0,n=1;
	for(;n<=N;i++){
		n*=2;
	}
	i--;        //找出每个一维幂次
	printf("2");
	if(i==0){
		printf("(%d)",i);
		}
	if(i>1){        //符合第二次递归的条件,题目要求只能用0,2表示
		printf("(");
		digui1(i);
		printf(")");
	}
	if((N-=(n/2))!=0){        //符合第一次递归的条件,N没有被表示完全
		printf("+");
		digui(N);
	}
}
int main(){
	int N;
	scanf("%d",&N);
	digui(N);
	return 0;
} 

? ?【附语】

我也想过用一个递归函数把这所有次的递归全部包含,因为这三次递归算法都一样,但是我也试过,递归函数要几种递归就要给函数加几个参数,大概是表示递归的状态吧,根据状态来判断下次递归的类型,但是难度太大。希望读者可以尝试一下。

? ? ? ?

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-02-04 10:51:31  更:2022-02-04 10:51:33 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 8:38:08-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码