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;
}
相关推荐
炸膛坦客14 分钟前
嵌入式 - 数据结构与算法:(1-4)数据结构 - 单链表的两个核心缺点(引入循环/双向链表)
c语言·数据结构·链表
2501_9327502619 分钟前
Java IO流基础全面详解:字节流、字符流
java·开发语言
冰暮流星25 分钟前
javascript之默认事件
开发语言·javascript·ecmascript
fengci.28 分钟前
CTF+随机困难题目
android·开发语言·前端·学习·php
l1t31 分钟前
DeepSeek总结的Python 3.14.5 发布候选版本
开发语言·python
雪度娃娃35 分钟前
设计模式——单例模式
开发语言·c++·设计模式
Cyber4K36 分钟前
【Python专项】进阶语法-日志分类与分析(2)
开发语言·前端·python
lbb 小魔仙40 分钟前
Python + LangChain 环境搭建完全指南:从零构建本地 RAG 知识库(附 Ollama 本地模型集成)
开发语言·python·langchain
风落无尘40 分钟前
Python 包发布全流程:从项目结构到 PyPI 上线,以及我踩过的那些坑
开发语言·python·pip
xxjj998a41 分钟前
PHP vs C#:两大编程语言终极对比
开发语言·c#·php