ChatGPT——用C++写一个求原根的程序
916 2023-05-04 11:41
用C++写一个高效求原根的程序,要求:输入一个数字,输出该数字的所有原根到d盘的"yuangen.txt"文件,并给出详细注释。
下面是一个用C++编写的程序,用于计算给定数字的所有原根,并将结果输出到 D 盘的 "yuangen.txt" 文件中。程序中包含了详细的注释。
#include <iostream>
#include <fstream>
#include <vector>
#include <cmath>
using namespace std;
// 函数声明
bool isPrime(int n);
int gcd(int a, int b);
int power(int base, int exp, int mod);
bool isPrimitiveRoot(int g, int p, vector<int>& factors);
// 主函数
int main() {
int p;
cout << "请输入一个素数:";
cin >> p;
if (!isPrime(p)) {
cout << p << " 不是一个素数!" << endl;
return 1;
}
// 找到 p-1 的所有质因数
int phi = p - 1;
vector<int> factors;
for (int i = 2; i <= sqrt(phi); i++) {
while (phi % i == 0) {
if (find(factors.begin(), factors.end(), i) == factors.end()) {
factors.push_back(i);
}
phi /= i;
}
}
if (phi > 1) {
factors.push_back(phi);
}
// 找出所有原根
vector<int> primitiveRoots;
for (int g = 2; g < p; g++) {
if (isPrimitiveRoot(g, p, factors)) {
primitiveRoots.push_back(g);
}
}
// 将结果写入文件
ofstream outFile("D:\\yuangen.txt");
if (outFile.is_open()) {
outFile << "原根为:\n";
for (int root : primitiveRoots) {
outFile << root << endl;
}
outFile.close();
cout << "原根已写入 D:\\yuangen.txt 文件。" << endl;
} else {
cout << "无法打开文件!" << endl;
}
return 0;
}
// 检查是否为素数
bool isPrime(int n) {
if (n < 2) return false;
for (int i = 2; i <= sqrt(n); i++) {
if (n % i == 0) return false;
}
return true;
}
// 计算最大公约数
int gcd(int a, int b) {
return b == 0 ? a : gcd(b, a % b);
}
// 快速幂计算
int power(int base, int exp, int mod) {
int result = 1;
base = base % mod;
while (exp > 0) {
if (exp % 2 == 1) {
result = (result * base) % mod;
}
exp = exp >> 1; // 右移一位,相当于整除2
base = (base * base) % mod;
}
return result;
}
// 检查 g 是否为原根
bool isPrimitiveRoot(int g, int p, vector<int>& factors) {
for (int factor : factors) {
int exponent = (p - 1) / factor;
if (power(g, exponent, p) == 1) {
return false;
}
}
return true;
}
以上程序可以有效地计算给定素数的所有原根,并将结果保存到指定文件中。程序中的函数分别负责检查素数、计算最大公约数、执行快速幂运算以及检查原根条件。
用C++写一个高效求质数的程序,要求:输入一个数字,输出该数字以内所有质数到d盘的"sushu.txt"文件,并给出详细注释。
下面是一个用C++编写的程序,用于计算给定数字以内的所有质数,并将结果输出到 D 盘的 "sushu.txt" 文件中。程序中包含了详细的注释。
#include <iostream>
#include <fstream>
#include <vector>
#include <cmath>
using namespace std;
// 函数声明
bool isPrime(int n);
void findPrimes(int limit, vector<int>& primes);
int main() {
int n;
cout << "请输入一个正整数:";
cin >> n;
if (n < 2) {
cout << "请输入大于等于2的整数!" << endl;
return 1;
}
// 存储质数的向量
vector<int> primes;
findPrimes(n, primes);
// 将结果写入文件
ofstream outFile("D:\\sushu.txt");
if (outFile.is_open()) {
outFile << "小于或等于 " << n << " 的质数有:\n";
for (int prime : primes) {
outFile << prime << endl;
}
outFile.close();
cout << "质数已写入 D:\\sushu.txt 文件。" << endl;
} else {
cout << "无法打开文件!" << endl;
}
return 0;
}
// 判断一个数是否为质数
bool isPrime(int n) {
if (n <= 1) return false; // 1 及以下不是质数
if (n <= 3) return true; // 2 和 3 是质数
if (n % 2 == 0 || n % 3 == 0) return false; // 剔除 2 和 3 的倍数
// 检查从 5 开始的质数,使用 6k ± 1 方法
for (int i = 5; i * i <= n; i += 6) {
if (n % i == 0 || n % (i + 2) == 0) {
return false;
}
}
return true;
}
// 查找小于等于 limit 的所有质数
void findPrimes(int limit, vector<int>& primes) {
for (int i = 2; i <= limit; ++i) {
if (isPrime(i)) {
primes.push_back(i); // 将质数添加到向量中
}
}
}
程序详细说明:
-
isPrime
函数:- 用于判断一个整数是否为质数。
- 处理小于等于 1 的情况,直接返回
false
。 - 对于小于等于 3 的数,返回
true
的情况。 - 剔除所有偶数和 3 的倍数。
- 使用 6k±1 方法来检查更大的数,其中 k 为正整数。
-
findPrimes
函数:- 用于查找小于等于给定限制的所有质数。
- 将找到的质数存入一个向量中。
-
文件输出:
- 程序将找到的质数写入 D 盘的 "sushu.txt" 文件中。
-
输入检查:
- 程序确保用户输入的数字大于等于 2。
-
控制台输出:
- 程序会在控制台显示文件写入成功的提示。
全部评论