C语言每日一题:16:数对。

思路一:基本思路

1.x,y均不大于n,就是小于等于n。

2.x%y大于等于k。

3.一般的思路使用双for循环去遍历每一对数。

代码实现:

c 复制代码
#include <stdio.h>
int main()
{
   int n = 0;
   int k = 0;
   //输入
   scanf("%d%d", &n, &k);

   int x = 0;
   int y = 0;
   long long count = 0;
   
    for(x=1;x<=n;x++)
    {
        for(y=1;y<=n;y++)
        {
            if(x%y>=k)
            count++;
        }
    }
   printf("%lld", count);
   return 0;
}

我们的运行结果是

我们在vs2022下测试代码的结果是正确的什么说明我们的代码思路是没有问题可以计算出结果但是呢,题目要求时间限制是1s,在vs运行出结果至少用了十秒。说明我们的时间复杂度过高当n比较大时时间复杂度是特别高的。

思路二:寻找规律推导公式

c 复制代码
#include <stdio.h>
int main()
{
   long n = 0;
   long k = 0;
   //输入
   scanf("%ld%ld", &n, &k);
   long count = 0;

   //1.当k=0的时候。
   if(k==0)
   {
        count=n*n;
   }
   else 
   {
        //只遍历我们行
        for(long y=k+1;y<=n;y++)
        {
           //计算对角线右
            long help = n % y < k ? 0 : (n % y) - k + 1;
            //计算对角线左
            count += (y - k) * (n / y) + help;
        }
   }
   
   printf("%ld\n",count);
   return 0;
}
相关推荐
Rust研习社1 分钟前
Reqwest 兼顾简洁与高性能的现代 HTTP 客户端
开发语言·网络·后端·http·rust
念越1 分钟前
Java 文件操作与IO流详解(File类 + 字节流 + 字符流全总结)
java·开发语言·io
71-35 分钟前
C语言练习——数组的练习(涉及顺序、二分查找,冒泡排序)
c语言·笔记·学习·排序算法·查找算法
格林威6 分钟前
面阵相机 vs 线阵相机:堡盟与Basler选型差异全解析 + Python实战演示
开发语言·网络·人工智能·python·数码相机·yolo·工业相机
小林望北13 分钟前
Kotlin 协程:StateFlow 与 SharedFlow 深度解析
android·开发语言·kotlin
盐烟13 分钟前
xpath-csv_doban_slider
开发语言·python
小学生-山海14 分钟前
【安卓逆向】WE Learn登录接口iv、pwd参数分析,加密逆向分析
开发语言·python·安卓逆向
Slow菜鸟15 分钟前
Java 开发环境安装指南(7) | Nginx 安装
java·开发语言·nginx
沐苏瑶15 分钟前
Java反序列化漏洞
java·开发语言·网络安全
进击的荆棘15 分钟前
C++起始之路——用哈希表封装myunordered_set和myunordered_map
开发语言·c++·stl·哈希算法·散列表·unordered_map·unordered_set