【牛客网】HJ99 自守数、OR86 返回小于 N 的质数个数

 作者:一个喜欢猫咪的的程序员 

专栏:《Leetcode》

喜欢的话:世间因为少年的挺身而出,而更加瑰丽。                                  ——《人民日报》


目录

HJ99 自守数 

 OR86 返回小于 N 的质数个数


HJ99 自守数 

自守数_牛客题霸_牛客网【牛客题霸】收集各企业高频校招笔面试题目,配有官方题解,在线进行百度阿里腾讯网易等互联网名企笔试面试模拟考试练习,和牛人一起讨论经典试题,全面提升你的技术能力icon-default.png?t=MBR7https://www.nowcoder.com/practice/88ddd31618f04514ae3a689e83f3ab8e?tpId=37&&tqId=21322&rp=1&ru=/ta/huawei&qru=/ta/huawei/question-ranking#:~:text=%E4%B8%8B%E4%B8%80%E9%A2%98-,HJ99%20%E8%87%AA%E5%AE%88%E6%95%B0,-%E9%A2%98%E7%9B%AE题目描述:

描述

自守数是指一个数的平方的尾数等于该数自身的自然数。例如:25^2 = 625,76^2 = 5776,9376^2 = 87909376。请求出n(包括n)以内的自守数的个数

数据范围:1≤n≤10000 

输入描述:

int型整数

输出描述:

n以内自守数的数量。

示例:


思路:

输入一个数n,从0-n中的每一个数i找自守数 ,判断i的平方i2大于10的m次方

当i2小于10时,直接让i2=-1,否则取余执行下一次循环。

时间复杂度:O(N^2)                空间复杂度:O(1)

代码:

#include <stdio.h>
#include <math.h>
int main()
{
    int max;
    scanf("%d", &max);
    int num = 0;
    for (int i = 0; i <= max; i++)
    {
        int i2 = i * i;
        int n=0;
        while (pow(10,n)<=i2) 
        {
            n++;
        }
        while (i2 >= i)
        {
            if (i2 == i)
            {
                num++;
                break;
            }
            if (i2 < 10)
            {
                i2 = -1;
            }
            else
            {
              i2=i2%(int)pow(10, n--);
            }
        }
    }
    printf("%d", num);
    return 0;
}

 OR86 返回小于 N 的质数个数

返回小于 N 的质数个数_牛客题霸_牛客网【牛客题霸】收集各企业高频校招笔面试题目,配有官方题解,在线进行百度阿里腾讯网易等互联网名企笔试面试模拟考试练习,和牛人一起讨论经典试题,全面提升你的技术能力icon-default.png?t=MBR7https://www.nowcoder.com/practice/9e7a88d6a00e404c8418602515a5046c?tpId=182&&tqId=34812&rp=1&ru=/ta/exam-all&qru=/ta/exam-all/question-ranking#:~:text=%E4%B8%8B%E4%B8%80%E9%A2%98-,OR86%20%E8%BF%94%E5%9B%9E%E5%B0%8F%E4%BA%8E%20N%20%E7%9A%84%E8%B4%A8%E6%95%B0%E4%B8%AA%E6%95%B0,-%E9%A2%98%E7%9B%AE题目描述:

描述

请考虑性能

输入描述:

一个整数N

输出描述:

小于N的质数数量

示例:


代码:

#include <stdio.h>
int main() {
    int n;
    scanf("%d",&n);
    int num=0;//个数
    for(int i=2;i<n;i++)
    {
        int m=2;
        int flag=0;
        while(m<i)
        {
            if(i%m==0)
            {
                flag=1;
                break;
            }
            m++;
        }
        if(flag==0)
        {
            num++;
        }
    }
    printf("%d",num);
    return 0;
}

  • 23
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 18
    评论
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学IT的小卢

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值