此题给定一个N,输出(10, N)之下的所有数字,看到我就会了啊,啪的一下就过了。
class Solution {
public:
vector<int> printNumbers(int n) {
vector<int> v;
int N = int(pow(10, n));
for(int i=1;i<N;i++)v.push_back(i);
return v;
}
};
结果一看题解,发现小丑真的是我自己。人家根本就没给范围啊,假如N是100,那是凉的透透的啊。所以要用大数加法做一下。由于每次只加1,代码还是比较简单的。
#define _CRT_SECURE_NO_WARNINGS
#include <tuple>
#include <cstdio>
#include <vector>
#include <iostream>
#include <algorithm>
typedef long long ll;
using namespace std;
int INF = 1 << 30;
int N = 10;
void add(string& s)
{
for(int i=s.size()-1;i>=0;i--)
{
if(s[i] == '9')s[i] = '0';
else
{
s[i] += 1;
break;
}
}
}
int main()
{
string s(N-1, '0');
string end(N-1, '9');
while(s != end)
{
add(s);
printf("%s\n", s.substr(s.find_first_not_of('0')).data());
}
}
还有一种优化,就是不要每次用字符串比较,这样每次都是O(N),可以在最高位产生进位时停止,可以省去比较的时间。这个判断的优化还是挺有用的。
#define _CRT_SECURE_NO_WARNINGS
#include <tuple>
#include <cstdio>
#include <vector>
#include <iostream>
#include <algorithm>
typedef long long ll;
using namespace std;
int INF = 1 << 30;
int N = 5;
int add(string& s)
{
for(int i=s.size()-1;i>=-1;i--)
{
if(i < 0)return 1;
if(s[i] == '9')s[i] = '0';
else
{
s[i] += 1;
return 0;
}
}
return 0;
}
int main()
{
string s(N-1, '0');
string end(N-1, '9');
while(1)
{
int bk = add(s);
if(bk)break;
printf("%s\n", s.substr(s.find_first_not_of('0')).data());
}
}
解法二:全排列做法
排列的做法即为从头到尾枚举0-9,由于这种自右向左从小到大的递增性,可以生成从1到对应位数的代码,很强,咱们在所有位枚举完后打印即可。
这个做法和全排列还不太一样,全排列是每个数字都必须出现。
#define _CRT_SECURE_NO_WARNINGS
#include <tuple>
#include <cstdio>
#include <vector>
#include <iostream>
#include <algorithm>
typedef long long ll;
using namespace std;
int INF = 1 << 30;
int N = 3;
void add(string& s, int idx)
{
if (idx >= s.size())
{
int p = s.find_first_not_of('0');
if (p >= 0)printf("%s\n", s.substr(p).data());
return;
}
for (int i = 0; i < 10; i++)
{
s[idx] = '0' + i;
add(s, idx + 1);
}
}
int main()
{
string s(N - 1, '0');
add(s, 0);
}