C语言第二十八练 对数的相关应用

简介: C语言第二十八练 对数的相关应用

第二十八练 对数的相关应用

求 N ! (1 <= N <= 5000)中有多少位数字。(只N的阶乘)

要求:1、输入正整数N 2、输出N!有多少位数字

第二十七练答案

以下是一个用C语言实现的程序,根据给定的整数n,计算满足条件1<=b<=a<=n 且 gcd(a,b)=a XOR b的整数对(a, b)的数量。程序中使用了gcd函数来计算最大公约数,使用异或操作符(^)来进行异或运算。

#include <stdio.h>

int gcd(int a, int b) {
    if (b == 0) {
        return a;
    }
    return gcd(b, a % b);
}

int countPairs(int n) {
    int count = 0;
    for (int a = 1; a <= n; ++a) {
        for (int b = 1; b <= a; ++b) {
            if (gcd(a, b) == (a ^ b)) {
                count++;
            }
        }
    }
    return count;
}

int main() {
    int n;
    printf("Enter a positive integer n: ");
    scanf("%d", &n);
    
    int result = countPairs(n);
    printf("Number of pairs (a, b) satisfying gcd(a, b) = a XOR b: %d\n", result);
    
    return 0;
}

在这个程序中,用户输入一个正整数n,程序会计算满足条件1<=b<=a<=n 且 gcd(a,b)=a XOR b的整数对(a, b)的数量,并输出结果。

上述答案时间复杂度比较高,下面是一个时间复杂度低一点的方法。

最容易想到的方法是枚举 a,b,双重循环加上求 gcd,总复杂度为 O(nnlogn),绝对 无法承受。如何减少枚举呢?注意到亦或运算的性质,如果 a^b=c,那么 a^c=b,既然 c 为 a, b 的最大公约数的话,那么我们可以从枚举 a 和 c 出发,那么就是枚举所有因子 c 及其可能 的倍数 a,和素数筛法一样,这样复杂度为 O(nlognlogn),n 最大为 30000000,复杂度还是 有点高,怎么减少复杂度呢?这就要通过一点数学知识或者找规律发现了,通过打印出所有 满足条件的 a,b,c 可以发现 a+b=c,所以可以将复杂度降为 O(nlogn),但是题目是多样例 输入,如果每次都需要 O(n*logn)计算答案的话,还是会超时,观察便可得知其实在计算 n 以内满足条件的 a,b 对数时比 n 小的数以内的对数都已经计算出来了,也就是说不需要重 复计算了,那么我们可以通过一次预处理,在计算的过程中统计每个 a 组合时的对数,之后 循环遍历一次全部加起来就可以知道每个 n 以内的答案了。


#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
using namespace std;
const int N = 30000000;
int a[N+5];

void pretreat() {
 for (int i = 1; i <= 15000000; i++) {
 for (int j = i<<1; j <= N; j += i) {
 if ((j ^ (j-i)) == i) a[j]++;
 }
 }
 for (int i = 2; i <= N; i++) a[i] += a[i-1];
}
int main() {
 pretreat();
 int t, ca = 0;
 scanf("%d", &t);
 while (t--) {
 int n;
 scanf("%d", &n);
 printf("Case %d: %d\n", ++ca, a[n]);
 }
 return 0;
}

答案和解析会在次日公布

注意事项

编写代码的时候,需要注意以下几点问题:

  • 头文件的引用需要放在代码的最顶部
  • 每个C语言程序中必须包含一个 main函数
  • void main(){}
  • int main(){return 0;}
  • C语言中每一行的结尾处必须要使用分号结尾
  • C语言中的引号需要使用双引号,双引号都是以一对一对的情况出现的
  • 在scanf键盘输入代码中,要使用 & 加变量名来读取一个键盘输入
  • 赋值语句是将右边的值赋给左边的变量,顺序不能反了
  • 需要注意代码的缩进格式,缩进为4个空格或者一个tab键为一组,但是要保证整篇代码里面风格一致,要么都是4个空格缩进,要么都是使用一个tab进行缩进
  • 需要养成随手保存的习惯,保存的快捷键一般是 ctrl + s
  • 注意大括号的使用,大括号是代码块,代表了一个块的代码是放在一起的
  • 注意整数型和实数型的转换,如果将实数赋值给一个整形变量,那么实数的小数部分将会被舍去;
  • 注意除法中,如果除数和被除数都是整数,那么结果也会是一个整数,小数部分会自动舍弃
  • 成对出现的标点符号
  • 单引号,双引号,小括号,中括号,大括号等,一般不单独出现
  • 如果代码有问题,然后附近又刚好有这些成对符号,请着重关注
  • 定义变量时,该打的逗号应该打上,不能写掉了
  • 编写++符号时,不要误写成了ff
  • 一个程序里面只能有一个main函数,除了main函数的其他函数都不能叫这个名字
  • 在调用函数时,入参都是使用的逗号隔开,一定不要使用分号隔开
  • 换行符是\n,不能错误写成/n
  • 输入输出格式化
  • %d对应整数
  • %c对应字符
  • %f对应实数
  • 不要写错或者写漏了
  • if条件语句当前行不能加分号,不然这个语句就没有意义了

更多

「欢迎来到C语言每日一练服务!」

在现代技术的飞速发展中,编程已经成为一项不可或缺的技能。C语言作为一门经典的编程语言,奠定了计算机科学的基石,为学习其他编程语言打下了坚实的基础。为了帮助大家更好地掌握C语言,我们特别推出了每日一练服务,旨在提供系统性、全面性的学习支持。

「我们的服务特点包括:」

  1. 「日常练习题目:」 每天我们会提供一道C语言练习题目,涵盖基础知识、算法、数据结构等多个领域。这些题目既有难度,又具有实际应用价值,帮助你锻炼编程技能。
  2. 「详细解析:」 我们不仅提供每道题的标准答案,还会提供详细的解析和优秀代码示例。通过对解题思路的深入剖析,你能够更好地理解和掌握各种编程技巧。
  3. 「互动学习社区:」 通过微信文章评论区建立了一个互动学习社区,供学员们交流讨论。你可以在这里提问问题、分享经验,与其他学员一起成长。
  4. 「个性化学习建议:」 根据你的学习表现,我们会为你推荐相应难度的练习题,确保你的学习过程既具挑战性,又不至于过于困难,保持学习的动力和兴趣。

「参与每日一练的好处:」

  • 「持续学习提升技能:」 每日坚持练习,你的编程技能将会得到持续提升,不断进步。
  • 「增强自信心:」 通过解决各种类型的问题,你将建立起对自己技能的信心,更加轻松应对编程挑战。
  • 「拓宽思路:」 每道题都是一个小挑战,通过解决这些问题,你将培养出灵活的思维,更好地应对实际编程工作中的挑战。
  • 「为未来发展奠定基础:」 无论你是初学者还是有一定经验的程序员,C语言每日一练都将为你未来的编程发展奠定坚实的基础。

加入我们的C语言每日一练服务,一起挑战编程难题,不断提升自己,走向编程高手的道路!

目录
相关文章
|
1月前
|
存储 算法 C语言
通义灵码在考研C语言和数据结构中的应用实践 1-5
通义灵码在考研C语言和数据结构中的应用实践,体验通义灵码的强大思路。《趣学C语言和数据结构100例》精选了五个经典问题及其解决方案,包括求最大公约数和最小公倍数、统计字符类型、求特殊数列和、计算阶乘和双阶乘、以及求斐波那契数列的前20项和。通过这些实例,帮助读者掌握C语言的基本语法和常用算法,提升编程能力。
63 4
|
1月前
|
存储 编译器 C语言
C语言:数组名作为类型、作为地址、对数组名取地址的区别
在C语言中,数组名可以作为类型、地址和取地址使用。数组名本身代表数组的首地址,作为地址时可以直接使用;作为类型时,用于声明指针或函数参数;取地址时,使用取地址符 (&),得到的是整个数组的地址,类型为指向该类型的指针。
ly~
|
1月前
|
网络协议 算法 关系型数据库
C语言的应用
C 语言因其高效性和对硬件的直接访问能力,在多个领域有广泛应用。在系统软件领域,它被用于开发操作系统(如 Unix 和 Linux 的内核)和嵌入式系统(如汽车电子控制系统)。在游戏开发中,C 语言常用于构建游戏引擎的底层部分(如 Unity 和 Unreal Engine 的核心模块)及性能要求高的独立游戏。此外,C 语言也用于数据库管理系统(如 MySQL 和 PostgreSQL 的核心功能)和网络编程(如 TCP/IP 协议栈和网络服务器的核心模块)。
ly~
36 3
|
1月前
|
Java Unix Linux
1.3 C语言的应用范围
C语言自20世纪80年代以来一直是主流编程语言,适用于小型计算机、个人电脑及大型机。因其高效紧凑且易于修改和移植,广泛用于软件开发。尽管后来C++和JAVA流行起来,但C语言仍然是软件行业核心,并在嵌入式系统、科学编程和操作系统开发如Linux中扮演重要角色。即使到现在,掌握C语言仍是一项重要技能。不是必须得是计算机专家才能使用C语言,学习C语言同时也能学到很多C++的知识。
49 8
|
5月前
|
编译器 C语言 C++
C语言学习记录——位段(内存分配、位段的跨平台、位段的应用)
C语言学习记录——位段(内存分配、位段的跨平台、位段的应用)
55 0
|
2月前
|
存储 C语言
数据结构基础详解(C语言): 树与二叉树的应用_哈夫曼树与哈夫曼曼编码_并查集_二叉排序树_平衡二叉树
本文详细介绍了树与二叉树的应用,涵盖哈夫曼树与哈夫曼编码、并查集以及二叉排序树等内容。首先讲解了哈夫曼树的构造方法及其在数据压缩中的应用;接着介绍了并查集的基本概念、存储结构及优化方法;随后探讨了二叉排序树的定义、查找、插入和删除操作;最后阐述了平衡二叉树的概念及其在保证树平衡状态下的插入和删除操作。通过本文,读者可以全面了解树与二叉树在实际问题中的应用技巧和优化策略。
|
2月前
|
存储 安全 C语言
C语言 二级指针应用场景
本文介绍了二级指针在 C 语言中的应用,
|
3月前
|
存储 搜索推荐 C语言
C语言中的指针函数:深入探索与应用
C语言中的指针函数:深入探索与应用
|
3月前
|
编译器 C语言
C语言中的浮点数:深入探索与应用
C语言中的浮点数:深入探索与应用
142 1
|
3月前
|
程序员 C语言
位操作在C语言中的解析与应用
位操作在C语言中的解析与应用
91 0