news 2026/5/19 19:46:01

UVa 10208 Liar or Not Liar that is the ...

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
UVa 10208 Liar or Not Liar that is the ...

题目描述

Macintosh\texttt{Macintosh}Macintosh先生是一位地主,他拥有的所有土地都是直角三角形,并且两条直角边的长度都是整数。他雇佣了一名员工来记录所有土地的信息,但报告只包含每块土地最长边(斜边)的平方值。也就是说,如果一块土地的三条边为aaabbbccc,其中ccc是斜边(最大边),那么报告中只记录c2c^2c2的值。

现在Macintosh\texttt{Macintosh}Macintosh先生怀疑这名员工是否诚实,他需要你根据报告中的数据判断这些值是否真的可能是某块直角三角形土地斜边的平方。

输入格式

输入包含若干行,每行是一个无符号整数NNN或形如N!N!N!NNN的阶乘)的数,其中4≤N≤100000004 \le N \le 100000004N10000000。每个数表示某块土地斜边的平方值。

输出格式

对于每行输入:

  • 如果输入是NNN,判断N\sqrt{N}N是否可能是某块土地的最长边。如果是,输出He might be honest.,否则输出He is a liar.
  • 如果输入是N!N!N!,除了进行上述判断外,如果N!N!N!本身不是合法的斜边平方,还需要输出需要用哪些质数去除N!N!N!,才能使其成为某个合法斜边的平方。如果这样的质数超过505050个,只输出最小的505050个。质数在同一行输出,用空格分隔。当然,如果N!N!N!本身就是合法斜边的平方,则不需要输出质数。

每组输出之间用一个空行分隔。

样例输入

10 12 98 99 4! 5! 6! 120!

样例输出

He might be honest. He is a liar. He might be honest. He is a liar. He is a liar. 3 He is a liar. 3 He might be honest. He is a liar. 7 23 31 67 71 79 83 103 107

题目分析

问题转化

题目本质上要求判断一个数MMM(可能是NNNN!N!N!)是否可以表示为两个整数的平方和,即是否存在整数aaabbb使得:

a2+b2=M a^2 + b^2 = Ma2+b2=M

这里MMM是斜边的平方c2c^2c2,注意ccc本身不一定是整数(题目只要求两条直角边是整数)。

数论基础:费马平方和定理

一个经典定理(费马平方和定理)指出:

一个正整数MMM可以表示为两个整数的平方和,当且仅当在MMM的质因数分解中,所有形如4k+34k+34k+3的质因子的指数都是偶数。

证明概要

  • 充分性:如果所有4k+34k+34k+3质因子的指数都是偶数,那么MMM可以写成2e×∏pi2ei×∏qj2fj2^e \times \prod p_i^{2e_i} \times \prod q_j^{2f_j}2e×pi2ei×qj2fj的形式,其中pip_ipi4k+14k+14k+1质数,qjq_jqj4k+34k+34k+3质数。利用平方和恒等式(a2+b2)(c2+d2)=(ac+bd)2+(ad−bc)2(a^2+b^2)(c^2+d^2) = (ac+bd)^2 + (ad-bc)^2(a2+b2)(c2+d2)=(ac+bd)2+(adbc)2,可以构造出平方和表示。
  • 必要性:如果存在4k+34k+34k+3质数qqq使得q2k+1∣Mq^{2k+1} \mid Mq2k+1M,假设M=x2+y2M = x^2 + y^2M=x2+y2,考虑模qqq可得矛盾。

算法设计

根据上述定理,我们只需要检查MMM的质因数分解中所有4k+34k+34k+3质因子的指数是否都是偶数。

1. 对于普通整数NNN

直接对NNN进行质因数分解,检查每个4k+34k+34k+3质因子的指数奇偶性。

2. 对于阶乘N!N!N!

需要计算N!N!N!中每个4k+34k+34k+3质数的指数。对于质数ppp,它在N!N!N!中的指数由勒让德公式给出:

exp(p,N!)=⌊Np⌋+⌊Np2⌋+⌊Np3⌋+⋯ \text{exp}(p, N!) = \left\lfloor \frac{N}{p} \right\rfloor + \left\lfloor \frac{N}{p^2} \right\rfloor + \left\lfloor \frac{N}{p^3} \right\rfloor + \cdotsexp(p,N!)=pN+p2N+p3N+

我们只需计算这个指数的奇偶性。如果某个4k+34k+34k+3质数pppN!N!N!中的指数是奇数,那么为了使其指数变为偶数(从而满足平方和条件),需要从N!N!N!中除去一个ppp。因此,所有指数为奇数的4k+34k+34k+3质数就是我们需要输出的质数列表。

算法优化

  1. 质数筛选:使用线性筛法预处理所有不超过10710^7107的质数,并单独记录所有4k+34k+34k+3质数。
  2. 指数奇偶性计算:对于阶乘的情况,使用勒让德公式计算,但可以提前终止(当pk>Np^k > Npk>N时)。
  3. 输出限制:只输出最小的505050个需要除去的质数。

时间复杂度

  • 筛法预处理:O(107)O(10^7)O(107),只需一次。
  • 普通整数判断:O(N/log⁡N)O(\sqrt{N} / \log N)O(N/logN),最坏情况下需要检查所有不超过N\sqrt{N}N4k+34k+34k+3质数。
  • 阶乘判断:需要检查所有不超过NNN4k+34k+34k+3质数,每个质数计算指数的时间为O(log⁡pN)O(\log_p N)O(logpN)。由于N≤107N \le 10^7N1074k+34k+34k+3质数大约有1.2×1061.2 \times 10^61.2×106个,但实际计算量较小,因为很多大质数的指数计算很快。

代码实现

// Liar or Not Liar that is the ...// UVa ID: 10208// Verdict: Accepted// Submission Date: 2025-12-16// UVa Run Time: 0.500s//// 版权所有(C)2025,邱秋。metaphysis # yeah dot net#include<bits/stdc++.h>usingnamespacestd;// 位运算宏定义,用于质数筛的位标记#defineGET(x)(B[x>>5]&(1<<(x&0x1F)))#defineSET(x)(B[x>>5]|=(1<<(x&0x1F)))constintMAXN=7000000,MAXB=10000010;intB[MAXB>>5];// 位数组,用于筛法intprimes[MAXN],cnt=0;// 存储所有质数vector<int>primes4k3;// 只存储4k+3形式的质数// 线性筛法voidsieve(){for(inti=2;i<MAXB;i++){if(!GET(i)){primes[cnt++]=i;if(i%4==3)primes4k3.push_back(i);// 记录4k+3质数}for(intj=0;j<cnt&&i*primes[j]<MAXB;j++){SET(i*primes[j]);if(i%primes[j]==0)break;}}}// 判断质数p在n!中的指数是否为奇数inlineboolisExponentOdd(intn,intp){intexp=0;while(n){n/=p;exp+=n;}return(exp&1);}// 判断整数n是否可以表示为两个整数的平方和inlineboolisSquares(intn){for(autop:primes4k3){intcnt=0;while(n%p==0){n/=p;cnt++;}if(cnt&1)returnfalse;// 4k+3质因子指数为奇数}returntrue;}intmain(){cin.tie(0);cout.tie(0);ios::sync_with_stdio(false);sieve();// 预处理质数表string line;boolfirstCase=true;while(cin>>line){if(!firstCase)cout<<'\n';firstCase=false;boolisFactorial=(line.back()=='!');intN;if(isFactorial)N=stoi(line.substr(0,line.size()-1));elseN=stoi(line);if(!isFactorial){// 普通整数情况cout<<(isSquares(N)?"He might be honest.\n":"He is a liar.\n");}else{// 阶乘情况vector<int>neededPrimes;for(autop:primes4k3){if(p>N)break;// 如果p在N!中的指数为奇数,则需要除去if(isExponentOdd(N,p)&&neededPrimes.size()<50)neededPrimes.push_back(p);if(neededPrimes.size()>=50)break;// 最多输出50个}if(neededPrimes.empty()){cout<<"He might be honest.\n";}else{cout<<"He is a liar.\n";for(size_t i=0;i<neededPrimes.size();i++){if(i>0)cout<<' ';cout<<neededPrimes[i];}cout<<'\n';}}}return0;}

总结

本题的关键在于理解费马平方和定理,将一个几何问题转化为数论问题。对于普通整数,直接检查质因数分解;对于阶乘,利用勒让德公式计算质数指数。算法的时间复杂度可以接受,主要优化在于只关注4k+34k+34k+3质数,并使用位运算加速筛法。

通过本题,我们不仅复习了经典的数论定理,还学习了如何高效处理阶乘的质因数分解问题,这对解决其他数论问题也有很好的借鉴意义。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/11 7:00:48

网易有道开源多音色情感TTS引擎EmotiVoice

网易有道开源多音色情感TTS引擎EmotiVoice 你有没有想过&#xff0c;机器发出的声音也能“笑”&#xff1f;能“哭”&#xff1f;甚至在讲述一段故事时&#xff0c;语气随着情节起伏而颤抖或激昂&#xff1f;这不再是科幻电影里的桥段——网易有道推出的 EmotiVoice&#xff0…

作者头像 李华
网站建设 2026/5/16 9:53:38

LobeChat能否分析用户评论?产品改进依据来源

LobeChat能否分析用户评论&#xff1f;产品改进依据来源 在当今产品迭代速度日益加快的背景下&#xff0c;企业越来越依赖真实、即时的用户反馈来驱动决策。传统的问卷调查和客服工单系统虽然有效&#xff0c;但往往存在响应滞后、信息碎片化、分类依赖人工等问题。有没有一种方…

作者头像 李华
网站建设 2026/5/16 4:48:38

无需前端基础!三步完成LobeChat可视化界面搭建

无需前端基础&#xff01;三步完成LobeChat可视化界面搭建 在大模型技术席卷各行各业的今天&#xff0c;越来越多的人希望将强大的AI能力融入自己的工作流——但问题也随之而来&#xff1a;如何让非技术人员也能轻松使用这些“聪明”的模型&#xff1f; OpenAI、Ollama、通义千…

作者头像 李华
网站建设 2026/5/10 8:55:30

SSH服务器STelnet登录配置全指南(含FTP基础介绍)

文档版本&#xff1a;V1.0一、FTP协议基础及应用概述在网络通信协议体系中&#xff0c;FTP&#xff08;File Transfer Protocol&#xff0c;文件传输协议&#xff09;是最早实现跨设备文件传输的标准协议之一&#xff0c;它基于客户端/服务器&#xff08;C/S&#xff09;架构&a…

作者头像 李华
网站建设 2026/5/10 10:32:10

网络资源建设如何助力企业效率提升?

在数字化转型的大潮中&#xff0c;许多企业都意识到网络资源建设的重要性。毕竟&#xff0c;一个高效稳定的网络环境是支撑业务顺畅运行的基础。然而&#xff0c;在实际操作过程中&#xff0c;不少公司却遇到了种种难题&#xff1a;要么是网络架构设计不合理导致频繁故障;要么是…

作者头像 李华
网站建设 2026/5/19 13:06:06

FaceFusion开源换脸工具详解:支持视频高清处理与唇形同步

FaceFusion开源换脸工具详解&#xff1a;支持视频高清处理与唇形同步 在AI视觉创作的浪潮中&#xff0c;人脸替换技术早已从“趣味玩具”走向专业化应用。无论是短视频中的虚拟主播、影视后期的数字替身&#xff0c;还是动画角色的表情驱动&#xff0c;高质量的人脸编辑能力正…

作者头像 李华