2018蓝桥杯—B组模拟题—U型数字


结果填空:U型数字
最近蒜头君喜欢上了U型数字,所谓U型数字,就是这个数字的每一位先严格单调递减,后严格单调递增。
比如 212 就是一个U型数字,但是 333, 98, 567, 31313,就是不是U型数字。

现在蒜头君问你,[1,100000] 有多少U型数字?


思路:因为1位和2位数字肯定不是U型数字,所以枚举100-100000的所有数字,因为u型数字从后往前或从前往后都是先递减再递增,从后往前找到第一个递增的位置(严格单调),然后判断是否一直递增,如果是则这个数是U型数字。


代码:

#include<bits/stdc++.h>


using namespace std;
const int maxn = 100050;


int vis[maxn], ans;


int judge(int x)
{
int flag = 1;
int a = 0, b = 15;
int cnt = 0;
while(x)
{
a = x%10;
x /= 10;
if(b == a)
   return 0;
if(b > a&&flag == 1)
{
b = a;
cnt ++;
}
if(b < a&&flag == 1&&cnt == 1)
   return 0;
if(b < a&&flag == 1&&b != 15)
   flag = 0;
if(b > a&&flag == 0)
   return 0;
if(b < a&&flag == 0)
   b = a;
}
if(flag == 0)
   return 1;
else
   return 0;
}


int main()
{
ans = 0;
for(int i = 100;i <= 100000;i++)
{
if(judge(i))
{
ans++;
printf("%d\n", i);
}
}
printf("\n");
printf("%d\n", ans);
return 0;
}//答案:8193


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值