考虑我们有一个数字d和上限n。我们必须找到所有0到n范围内包含d的数字。因此,如果n = 20,数字为3,则数字将为[3,13]。
为了解决这个问题,我们将每个数字都当作字符串,然后如果字符串中存在数字,则将打印该数字,否则忽略该数字。
#include<iostream>
using namespace std;
int getAllNumWithDigit(int n, int d) {
string str = "";
str += to_string(d);
char ch = str[0];
string p = "";
p += ch;
for (int i = 0; i <= n; i++) {
str = "";
str = str + to_string(i);
int index = str.find(p);
if (i == d || index!=-1)
cout << (i) << " ";
}
}
int main() {
int n = 100; int d = 3;
getAllNumWithDigit(n, d);
}输出结果
3 13 23 30 31 32 33 34 35 36 37 38 39 43 53 63 73 83 93