在C ++中找到包含数字d的数字

考虑我们有一个数字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