古希腊数学家毕达哥拉斯在自然数研究中发现: 220的所有真约数(即不是自身的约数)之和为:1+2+4+5+10+11+20+22+44+55+110=284。 而284的所有真约数为1、2、4、71、 142,加起来恰好为220。 人们对这样的数感到很惊奇,并称之为亲和数。一般地讲,如果两个数中任何一个数都是另一个数的真约数之和,则这两个数就是亲和数。 注意这两个数是不同的. 你的任务就编写一个程序, 输出n以内的亲和数 输入 读入一个整数 𝑛 [ 1 , 10 5 ] 输出 每行一对亲和数, 小的在前, 大的在后 多对亲和数,按照第一个数由小到大排序。 样例输入 复制 2290 样例输出 复制 220 284 1184 1210
```python def sum_of_divisors(n): """计算n的所有真约数之和""" if n <= 1: return 0 total = 1 # 1是所有大于1的数的真约数 for i in range(2, int(n0.5) + 1): if n % i == 0: total += i if i != n // i: # 避免重复添加平方根 total += n // i return total def find_amicable_numbers(n): """找出n以内的所有亲和数对""" amicable_pairs = [] for a in range(2, n + 1): b = sum_of_divisors(a) if b > a and b <= n: # 确保b在范围内且a < b if sum_of_divisors(b) == a: amicable_pairs.append((a, b)) return amicable_pairs def main(): n = int(input()) pairs = find_amicable_numbers(n) for a, b in pairs: print(f"{a} {b}") if __name__ == "__main__": main() ``` [2026-01-11 17:40:43 | AI问答 | 258点数解答]
- [DeepSeek] 古希腊数学家毕达哥拉斯在自然数研究中发现: 220的所有真约数(即不是自身的约数)之和为:1+2+4+5+10+11+20+22+44+55+110=284。 而284的所有真约数为1、2、4、71、 142,加起来恰好为220。 人们对这样的数感到很惊奇,并称之为亲和数。一般地讲,如果两个数中任何一个数都是另一个数的真约数之和,则这两个数就是亲和数。 注意这两个数是不同的. 你的任务就编写一个程序, 输出n以内的亲和数 输入 读入一个整数 𝑛 [ 1 , 10 5 ] 输出 每行一对亲和数, 小的在前, 大的在后 多对亲和数,按照第一个数由小到大排序。 样例输入 复制 2290 样例输出 复制 220 284 1184 1210(258点数解答 | 2026-01-11 17:40:43)31
- [字节豆包] 所谓亲和数对,是指两个不同的自然数,其中任何一个数的真因数之和都恰好等于另一个数。例如:220 和 284 就是一对亲和数对。 220 的全部真因数包括:1、2、4、5、10、11、20、22、44、55、110, 它们的和恰为 284; 284 的全部真因数包括:1、2、4、71、142,它们的和也恰好为 220。 据说,两个好朋友佩带写有亲和数对的护身符可使两人保持良好的友谊。 请编写程序,输入区间的下限和上限,若该区间内存在亲和数对,则输出区间内的全部亲和数对,否则输出 none。 输入格式: 两个正整数 a 和 b,且 a ≤ b ≤ 100000000,即区间 [a, b] 的下限和上限 输出格式: 若存在亲和数对,则输出若干行,每行一个亲和数对,均在区间 [a, b] 内,且前者小于后者,两者以空格间隔;否则输出 none。 用c语言(258点数解答 | 2024-11-18 21:26:17)279
- [DeepSeek] 通常,人们习惯将所有 位二进制串按照字典序排列,例如所有 2 位二进制串按字典序从小到大排列为:00,01,10,11。 格雷码(Gray Code)是一种特殊的 位二进制串排列法,它要求相邻的两个二进制串间**恰好**有一位**不同**,特别地,第一个串与最后一个串也算作相邻。 所有 2 位二进制串按格雷码排列的一个例子为:00,01,11,10。 位格雷码不止一种,下面给出其中一种格雷码的生成算法: 1. 1 位格雷码由两个 1 位二进制串组成,顺序为:0,1。 2. 位格雷码的前 个二进制串,可以由依此算法生成的 位格雷码(总共 个 位二进制串)按**顺序**排列,再在每个串前加一个前缀 0 构成。 3. 位格雷码的后 个二进制串,可以由依此算法生成的 位格雷码(总共 个 位二进制串)按**逆序**排列,再在每个串前加一个前缀 1 构成。 综上, 位格雷码,由 位格雷码的 个二进制串按顺序排列再加前缀 0,和按逆序排列再加前缀 1 构成,共 个二进制串。另外,对于 位格雷码中的 个 二进制串,我们按上(443点数解答 | 2026-01-05 12:21:49)25
- [DeepSeek] 题目描述 通常,人们习惯将所有<math xmlns="http://www.w3.org/1998/Math/MathML"> <mi>n</mi> </math> 位二进制串按照字典序排列,例如所有 2 位二进制串按字典序从小到大排列为:00,01,10,11。 格雷码(Gray Code)是一种特殊的 <math xmlns="http://www.w3.org/1998/Math/MathML"> <mi>n</mi> </math> 位二进制串排列法,它要求相邻的两个二进制串间**恰好**有一位**不同**,特别地,第一个串与最后一个串也算作相邻。 所有 2 位二进制串按格雷码排列的一个例子为:00,01,11,10。 <math xmlns="http://www.w3.org/1998/Math/MathML"> <mi>n</mi> </math>位格雷码不止一种,下面给出其中一种格雷码的生成算法: 1. 1 位格雷码由两个 1 位二进制串组成,顺序为:0,1。 2.<math xmlns="http://www.w3.org/1998/Mat(726点数解答 | 2026-01-13 12:31:37)30
- [DeepSeek] 题目描述 输入四个整数 x , y , a , b x,y,a,b,请你按照要求输出 x ∼ y x∼y 之间的所有数。 要求: 不要输出数字 a a。 不要输出大于等于数字 b b 的数。 输入格式 输入包括一行,包含四个整数 x , y , a , b x,y,a,b,数字之间用空格隔开。 输出格式 输出包括一行,为 x ∼ y x∼y 之间符合要求的数字。 input1 复制 10 20 13 17 output1 复制 10 11 12 14 15 16 input2 复制 50 55 52 100 output2 复制 50 51 53 54 55 样例解释 对于样例 1 1: 样例要求输出 10 ∼ 20 10∼20 之间不是 13 13, 且小于 17 17 的数,故有 10 , 11 , 12 , 14 , 15 , 16 10,11,12,14,15,16。 数据规模与约定 对于 100 % 100% 的数据, 1 ≤ x ≤ y ≤ 100 1≤x≤y≤100, x ≤ a ≤ y x≤a≤y, x ≤ b x≤b。 C++程序(138点数解答 | 2025-07-19 20:44:46)324
- [字节豆包] using namespace std; int main(){ int n,m,k; cin>>n>>m>>k; int a[110][110],b[110][110],c[110][110]; for(int i=0; i<n; i++){ for(int j=0; j<m; j++){ cin>>a[i][j]; } } for(int i=0; i<m; i++){ for(int j=0; j<k; j++){ cin>>b[i][j]; } } for(int i=0; i<n; i++){ for(int j=0; j<k; j++){ c[i][j]=0; for(int q=0; q<m; q++){ c[i][n]+=a[i][q]*b[q][j]; } } } for (int i = 0; i < n; i++) { for (int j = 0; j < k; j++) { if (j != k - 1) { (673点数解答 | 2025-12-01 14:12:52)31
- [字节豆包] 题目描述 输入三个整数 x , y , z x,y,z, 如果 x x为奇数,输出 1 ∼ y 1∼y之间的所有数,如果 x x为偶数,输出 1 ∼ z 1∼z之间的所有数。 输入格式 输入包括一行,包含三个整数 x , y , z x,y,z,数字之间用空格隔开。 输出格式 输出包括一行 如果 x x为奇数,输出 1 ∼ y 1∼y之间的所有数,如果 x x为偶数,输出 1 ∼ z 1∼z之间的所有数,输出时,数与数之间用1个空格隔开。 input1 复制 1 10 5 output1 复制 1 2 3 4 5 6 7 8 9 10 input2 复制 4 20 4 output2 复制 1 2 3 4 样例解释 对于样例 1 1: x x是奇数, y = 10 y=10,因此输出 1 ∼ 10 1∼10。 对于样例 2 2: x x是偶数, z = 10 z=10,因此输出 1 ∼ 4 1∼4 。 c++ (391点数解答 | 2025-06-14 09:57:45)302
- [字节豆包] 题目描述 输入四个整数 x , y , a , b x,y,a,b,请你按照要求输出 x ∼ y x∼y 之间的所有数。 要求: 不要输出数字 a a。 不要输出大于等于数字 b b 的数。 输入格式 输入包括一行,包含四个整数 x , y , a , b x,y,a,b,数字之间用空格隔开。 输出格式 输出包括一行,为 x ∼ y x∼y 之间符合要求的数字。 input1 复制 10 20 13 17 output1 复制 10 11 12 14 15 16 input2 复制 50 55 52 100 output2 复制 50 51 53 54 55 样例解释 对于样例 1 1: 样例要求输出 10 ∼ 20 10∼20 之间不是 13 13, 且小于 17 17 的数,故有 10 , 11 , 12 , 14 , 15 , 16 10,11,12,14,15,16。 数据规模与约定 对于 100 % 100% 的数据, 1 ≤ x ≤ y ≤ 100 1≤x≤y≤100, x ≤ a ≤ y x≤a≤y, x ≤ b x≤b。c++ (304点数解答 | 2025-10-25 20:12:27)71
- [字节豆包] 用C++给定一个整数 N N,判断其正负。如果 N > 0 N>0,输出 p o s i t i v e positive; 如果 N = 0 N=0,输出 z e r o zero; 如果 N < 0 N<0,输出 n e g a t i v e negative。 输入 一个整数 N ( − 10 9 ≤ N ≤ 10 9 ) N(−10 9 ≤N≤10 9 )。 输出 如果 N > 0 N>0, 输出 p o s i t i v e positive; 如果 N = 0 N=0, 输出 z e r o zero; 如果 N < 0 N<0, 输出 n e g a t i v e negative。 回答篇幅:越详细越好(610点数解答 | 2026-01-24 22:28:14)33
- [字节豆包] 用C++给定一个整数 N N,判断其正负。如果 N > 0 N>0,输出 p o s i t i v e positive; 如果 N = 0 N=0,输出 z e r o zero; 如果 N < 0 N<0,输出 n e g a t i v e negative。 输入 一个整数 N ( − 10 9 ≤ N ≤ 10 9 ) N(−10 9 ≤N≤10 9 )。 输出 如果 N > 0 N>0, 输出 p o s i t i v e positive; 如果 N = 0 N=0, 输出 z e r o zero; 如果 N < 0 N<0, 输出 n e g a t i v e negative。(150点数解答 | 2026-01-24 22:29:16)37
- [DeepSeek] 因数:又称为约数,如果整数 𝑎 除以整数 𝑏 的商正好是整数而没有余数,我们就说 𝑏 是 𝑎 的因数 质数:又称为素数,一个大于 1 的自然数,除了 1 和它自身外,不能被其他自然数整除的数叫做质数。 2 是最小的质数 质因数:如果一个数 𝑎 的因数 𝑏 同时也是质数,那么 𝑏 就是 𝑎 的一个质因数,例如: 8 = 2 ∗ 2 ∗ 2 , 2 就是 8 的质因数, 12 = 2 ∗ 2 ∗ 3 , 2 和 3 就是 12 的质因数。 给定两个正整数 𝑁 和 𝑀 ( 1 <= 𝑁 <= 𝑀 <= 10 7 ) ,统计 𝑁 到 𝑀 之间(含 𝑁 和 𝑀 )每个数所包含的质因数的个数,输出其中最大的个数。 例如: 当N=6,M=10,6到10之间 6的质因数是2、3,共有2个 7的质因数是7,共有1个 8的质因数是2、2、2,共有3个 9的质因数是3、3,共有2个 10的质因数是2、5,共有2个 6到10之间的数中质因数最多的是8,质因数有3个,故输出3。 样例输入 复制 6 10 样例输出 复制 3(245点数解答 | 2026-01-18 12:43:51)20
- [字节豆包] 子序列:是指在序列中选择某些元素,按照序列中的顺序连接在一起形成的。比如 blm、bl、oea、ma 都是 bolema 的子序列。但 loe 这个序列不是。我们定义子序列长度为子序列中包含的元素数量,比如 blm 的长度为 3,bl 的长度为 2。如果没有特殊说明,空序列和整个序列都是原序列的一个子序列。我们一般会用非空子序列来排除空序列,用真子序列来排除整个序列,用非空真子序列来同时排除两个。 子串:是指在序列中选择连续的某些元素,按照序列中的顺序连接在一起形成的,所以子串也常被称作连续子序列。比如 bol、lem 都是 bolema 的子串。但 blm 不是。与子序列相同,子串包含的元素个数也被称为子串的长度,同时也有“非空”、“真”等描述方法。 现在小a得到了一个仅包含英文小写字母的字符串 s,小a想要在其中找到一个子串 t,使得 bolema 是 t 的子序列。显然有可能有多个这样的 t,小a想要一个知道最短的 t 的长度是多少。 比如当 s 为 bboboxleymabobo 时,子串 boboxleyma、boxleymabobo、boxleyma 等都包含子序列(188点数解答 | 2024-11-15 20:51:47)293