#include #include char str[60000];//(5桁×10000件)+(空白1万-1) = 59999文字まで使われる可能性がある int str_len = 0; /// /// グローバル変数strの中身を入力された文字列で上書きする /// void ReadString() { char c = getchar(); str_len = 0; while (c != '\n') { str[str_len] = c; c = getchar(); str_len++; } } /// /// ReadStringの文字列のうち、スペースで区切られた左側か右側を取得する /// /// 左が欲しければtrue,右ならfalse /// 引数に対応した側の数字を返す int GetLR(int leftIs) { int cnt = 0; long num = 0; long left = 0; long right = 0; while (1) { if (cnt >= str_len) { right = num; break; } if (str[cnt] == ' ') { left = num; num = 0; cnt++; continue; } num = num * 10 + (str[cnt] - '0'); cnt++; } if (leftIs) { return left; } else { return right; } } long main() { ReadString(); long a = GetLR(1); long b = GetLR(0); for (long long i = a;i <= b;i++) { if (i % 3 == 0) { printf("%lld\n",i); continue; } for (long long j = 1LL;j < i * 10;j*=10) { if ((i%(j*10))/j == 3) { printf("%lld\n",i); break; } } } }