12:打印 1 到最大的 n 位数
题目:输入数字 n。按顺序打印出从 1 到 最大的 n 位十进制数。比方输入 3 ,则打印出 1、2 、3 一直到最大的3位数即 999。
解析:
easy知道不能用 int 等数字类型表示(大数问题)
在字符串上模拟数字加法
关键点:
1. 怎样用字符串表示n位数?
2. 怎样实现字符串数的自增操作?
3. 怎样打印一个字符串数?
- 申请长度是n+1的字符数组number。 number[0] 是最高位, number[n-1]最低位, number[n] = ‘\0’
- 首先把字符串中的每个数字都初始化为’0’ (注意是字符’0’,不是0)。然后每一次为字符串表示的数字加 1.
- 自增操作时。通过最高位是否会产生进位来推断是否到达最大数。
- 打印字符串数时,应该省略掉高位的无效0
#include <iostream>
#include <stdio.h>
using namespace std;
bool Increment(char* number, int n);
void PrintNum(char* number, int n);
void Print1ToMaxOfNDigits(int n) {
if (n <= 0) // 仅仅要有输入就要考虑输入合法性问题
return;
char* number = new char[n + 1]; // 最后一位放 '\0'
memset(number, '0', n); // 注意是 '0' 不是 0
number[n] = '\0';
while (Increment(number, n) == true) {
PrintNum(number, n);
}
delete []number;
}
bool Increment(char* number, int n)
{
int sum = 0, carry = 0;
for (int i = n - 1; i >= 0; i--) {
sum = (number[i] - '0') + carry;
if (i == n - 1) // 在末位 + 1
sum++;
if (sum >= 10) {
if (i == 0) // 最高位产生进位,已到达最大数
return false;
sum -= 10;
carry = 1;
number[i] = '0' + sum;
} else {
number[i] = '0' + sum; // 已无进位,自增结束
break;
}
}
return true;
}
void PrintNum(char* number, int n)
{
int i = 0;
while (number[i] == '0') // 跳过前面 '0'
i++;
for (; i < n; i++)
printf("%c", number[i]);
cout << " ";
}
int main()
{
Print1ToMaxOfNDigits(-1);
Print1ToMaxOfNDigits(0);
Print1ToMaxOfNDigits(3);
// Print1ToMaxOfNDigits(10);
}
全排列法递归打印
我们把每位数字都从 0~9 排列一遍就能得到全部的十进制数,仅仅是打印时省略掉高位无效 0
通过递归实现。从最高位開始。每一位都可能是0~9中的一个数。针对每一种可能设置下一位。递归结束条件是当我们设置了数字的最后一位。
void Print1ToMaxOfNDigits2(int n) {
if (n <= 0)
return;
char* number = new char[n + 1];
memset(number, '0', n);
number[n] = '\0';
Print1ToMaxOfNDigits2Recurisively(number, n, 0);
}
void Print1ToMaxOfNDigits2Recurisively(char* number, int len, int index) {
if (index == len) {
PrintNum(number, len); // 使用上文中的打印函数
return;
}
for (int i = 0; i < 10; i++) {
number[index] = '0' + i;
Print1ToMaxOfNDigits2Recurisively(number, len, index + 1);
}
}
12:打印 1 到最大的 n 位数的更多相关文章
- 剑指offer编程题Java实现——面试题12打印1到最大的n位数
题目:打印1到最大的n位数 输入数字n,按顺序打印输出从1到最大的n位十进制数,比如输入3,打印从1到999. 这道题考察的地方是如何表示大数问题.由于n是任意大的数组,如果n太大的话n位数就超过了l ...
- 面试题12:打印1到最大的n位数
// 面试题12_打印1到最大的n位数.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> ...
- 题目12 打印1到最大的n位数
///////////////////////////////////////////////////////////////////////////////////// // 2.打印1到最大的n位 ...
- 剑指Offer:面试题12——打印1到最大的n位数(java实现)
问题描述: 输入数字n,按顺序打印出从1到最大的n位十进制数,比如输入3,则打印出1,2,3一直到最大的3位数即999. 思路1:最简单的想法就是先找出最大的n位数,然后循环打印即可. public ...
- 12 打印1到最大的n位数
输入数字 n,按顺序打印出从 1 最大的 n 位十进制数.比如输入 3,则打印出 1.2.3 一直到最大的 3 位数即 999.由于 n 可能会非常大,因此不能直接用 int 表示数字,而是用 cha ...
- 《剑指offer》面试题12 打印1到最大的n位数 Java版
书中方法:这道题的一个陷阱在于不能用int或者long去存储你要打印的数,然后用打印函数打印,因为这个数可能会很大.如果加1后超出了最大的n位数,就不打印了.用最高位是否进位判断是否结束,打印的时候注 ...
- 剑指offer-面试题12.打印1到最大的n位数
题目:输入数字n,按照打印出从1最大的n位10进制数.比如3,则 打印出1.2.3一直到最大的3位数即999 1.你觉得如果面试会有这么简单的题,那 只能说明你---太天真. 2.n=3尚可,如果n= ...
- 《剑指offer》面试题12:打印1到最大的n位数
面试题12:打印1到最大的n位数 剑指offer题目12,题目如下 输入数字n,按顺序打印出1到最大的n位十进制数,比如输入3,则打印出1,2,3一直到最大的三位数999 方法一 和面试题11< ...
- 12:打印1到最大的n位数
面试题12:打印1到最大的n位数 剑指offer题目12,题目如下 输入数字n,按顺序打印出1到最大的n位十进制数,比如输入3,则打印出1,2,3一直到最大的三位数999 方法一 和面试题11< ...
- 【面试题012】打印1到最大的n位数
[面试题012]打印1到最大的n位数 大数问题 字符串中的每一个字符都是‘0’到‘9’之间的某一个字符,用来表示数字中的一位,因为数字最大是n位的,因此我们需要一个长度为n+1的字符串,字符串的最后 ...
随机推荐
- 日志log配置理解
实际生产中,每天都有大量的日志生成,单个文件(FileAppender)已经不能满足要求,RollingFileAppender继承了FileAppender,并提供了更多的功能: 每天生成一个日志文 ...
- HDU 3709
真是跪了,一看范围就不会往枚举的方向想,没想到真用枚举加剪枝了...->——-> 解释一下代码中的上限: 例如4567,当枚举最高位时,很明显不能超过4,所以有上限,但当最高位为3以下时, ...
- 关于C++构造函数一二
关于构造函数的调用顺序: 1.继承关系 2.从属关系 3.static声明的从属关系 关于拷贝构造函数的声明: classname(const classname & rhs) #includ ...
- Ruby按照换行符进行分割
Ruby按照换行符进行分割 string.split(/\n/)
- sedna载入xml文件
如果有一个xml文件a.xml.须要把它载入到sedna数据库xml_db里. sedna是通过se_term把xml载入到数据库的.有两种方法: 1.通过se_term的-query參数. se_t ...
- Server Tomcat v8.0 Server at localhost was unable to start within 45 seconds. If the server requires
Server Tomcat v8.0 Server at localhost was unable to start within 45 seconds. If the server requires ...
- 杂项-Java:Shiro(Java安全架构)
ylbtech-杂项-Java:Shiro(Java安全架构) Apache Shiro是一个强大且易用的Java安全框架,执行身份验证.授权.密码和会话管理.使用Shiro的易于理解的API,您可以 ...
- 关于content-type
content-type 包含了表单类型和边界字符串信息. 关于content-type get请求的headers中没有content-type这个字段 post 的 content-type 有两 ...
- Rabbit MQ 学习 (一)Window安装Erlang环境
之前也没有用过Rabbit MQ ,最近正在学习中,记性不好,特意记一下. 百度一下 先得 安装 Erlang 并且 设置环境变量. 在Erlang 官网去下载,那个慢呀... 还好CSDN 里有人提 ...
- 维基百科 MediaWiki API 解析
使用开放的 API 做一个自己的小项目,是一个很好的学习方法.但好像开放的 API 选择并不多.这里给大家多一个选择,简单介绍一下维基百科使用的 MediaWiki API. 简介 先简单介绍几个容易 ...