题解 | #自守数#

自守数

https://www.nowcoder.com/practice/88ddd31618f04514ae3a689e83f3ab8e

#include <bits/stdc++.h>
using namespace std;

inline int findk(int& n){
    int k = 1;
    while(k<=n){
        k*=10;
    }
    return k;
}

int main() {
    int n;
    while (cin >> n) {
        int cnt = 1;
        for(int i=1;i<=n;i++){
            if(((i*i-i)%findk(i))==0) cnt++;
        }
        cout<<cnt;
    }
}

循环有点丑陋,不知道还有没有更简单的位操作方法

全部评论

相关推荐

点赞 评论 收藏
分享
每晚夜里独自颤抖:要求太多的没必要理
点赞 评论 收藏
分享
测试糕手手:社会第一课,随便吹牛逼,直接说四个月,别老实。老实人只会被欺负
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务