GESP认证C++编程真题解析 | 202506 四级

news/2026/1/17 21:33:35/文章来源:https://www.cnblogs.com/guolianggsta/p/19497213

​欢迎大家订阅我的专栏:算法题解:C++与Python实现!
本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战!

专栏特色
1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的代码实现与详细指导,帮助您夯实算法基础。
2.系统化学习路径:按照算法类别和难度分级,从基础到进阶,循序渐进,帮助您全面提升编程能力与算法思维。

适合人群:

  • 准备参加蓝桥杯、GESP、CSP-J、CSP-S等信息学竞赛的学生
  • 希望系统学习C++/Python编程的初学者
  • 想要提升算法与编程能力的编程爱好者

附上汇总帖:GESP认证C++编程真题解析 | 汇总


单选题

第1题

在C++中,声明一个指向整型变量的指针的正确语法是( )。

A.int* ptr;

B.*int ptr;

C.int ptr*;

D.ptr int;

【答案】:A

【解析】

定义一个指针变量需要将解引用运算符*写在数据类型和变量名之间。

第2题

下面的函数接收一个 3 行 4 列的二维数组并输出其中元素,则横线上不能填写( )。

void printArray(____) {for (int i=0; i<3; ++i)for (int j=0; j<4; ++j)std::cout << arr[i][j] << " ";
}

A.int arr[3][4]

B.int arr[][4]

C.int (*arr)[4]

D.int** arr

【答案】:D

【解析】

当二维数组作为一个参数传递时,第二维度的数组大小是不能省略的。

第3题

在C++中, int arr[3][4] 和 int* arr = new int[12] 均可模拟一个 3 行 4 列的二维数组。关于这两种方 式,下面说法错误的是( )。

A.int arr[3][4] 在栈上分配空间,适合数组较小的情况

B.int* arr = new int[12] 在堆上分配空间,数组较大时也适用

C.这两种方式申请的内存空间都是连续的

D.这两种方式申请的内存都能自动释放

【答案】:D

【解析】

A. int arr[3I[4]在栈上分配空间,适合数组较小的情况。
正确。栈的空间通常比较小,只适合处理较小的数组。过大的数组可能导致栈溢出。

B. int* arr = new int[12]在堆上分配空间,数组较大时也适用。
正确。堆的空间较大,适合分配较大的数组。但是,这种方式需要手动释放内存。

C.这两种方式申请的内存空间都是连续的。
正确。无论是栈上分配还是堆上分配,数组的内存空间都是连续的。

D.这两种方式申请的内存都能自动释放。
错误。静态数组(栈上分配)在作用域结束时由编译器自动释放。但是,动态数组(堆上分配)的内存不会自动释放,需要程序员显式调用 delete[]来释放内存,否则会导致内存泄漏。

第4题

关于以下 C++代码,说法正确的是( )。

int main() {greet();return 0;
}void greet() {cout << "Hello!" << endl;
}

A.正确编译并输出 Hello!

B.编译错误:找不到函数 greet()

C.编译警告但可以运行

D.链接错误

【答案】:B

【解析】

如果没有声明函数,函数的定义必须写在调用之前,该代码没有声明该函数且将定义写在了调用后面,会发生编译错误。

第5题

在C++中,如果希望通过函数修改传入的结构体对象的内容,应该使用哪种参数传递方式?

A.值传递或引用传递

B.值传递或指针传递

C.引用传递或指针传递

D.仅指针传递

【答案】:C

【解析】

需要修改传入对象的内容,需要修改实参,应该使用引用传递或者指针传递。

第6题

以下哪个选项正确描述了C++中形参和实参的区别?

A.形参是函数调用时传递给函数的具体值,实参是函数定义中声明的变量。

B.形参是函数定义中声明的变量,实参是函数调用时传递给函数的具体值。

C.形参和实参在函数调用时是完全相同的。

D.形参只在函数内部可见,实参在函数外部可见。

【答案】:B

【解析】

形参:函数定义时声明的变量,是一个占位符,用来接收调用时传递的值。
实参:函数调用时传递给函数的具体值,是形参的实际数据来源。

第7题

运行如下代码会输出( )。

int value = 100;void print1() {int value = 50;cout << value << " ";cout << ::value << " ";
}void print2() {cout << value << " ";
}print1();
print2();

A.100 100 100

B.50 50 50

C.50 100 100

D.50 50 100

【答案】:C

【解析】

局部变量优先级更高,当局部变量与全局变量同名时,优先使用局部变量。
使用::可以显式访问全局变量,即便当前作用域内存在同名的局部变量。

第8题

小杨在整理一副扑克牌的所有红心扑克牌,使其从小到大排列。他的做法是:最开始抓到第1张扑克牌被认为已经排好序;然后抓第2张扑克牌,将其插入至有序部分的正确位置;不断循环步骤,每次将新抓到扑克牌插入至有序部分,直至抓完所有扑克牌,这样抓牌结束时就完成了扑克牌的排序。小杨这种整理扑克牌的方式与( )排序 的方式最接近。

A.冒泡排序

B.插入排序

C.选择排序

D.直接排序

【答案】:B

【解析】

题目中使用的方法为将每个元素在一个有序的序列中插入其正确的位置,这正是插入排序的思想。

第9题

以下哪种情况是使用插入排序的合适场景?

A.数据量非常大,且乱序严重

B.希望获得稳定排序,但不要求实时性

C.数据几乎有序,只需少量调整

D.想在交换次数最少的前提下排好大数组

【答案】:C

【解析】

如果数据几乎有序,则只需要将错误的数据插入到其正确的位置即可,使用插入排序。

第10题

以下关于递推算法基本思想的描述,正确的是( )。

A.递推算法通过将问题分解为相互独立的子问题来解决。

B.递推算法从已知的基础情况出发,通过某种关系逐步推导出更大规模问题的解。

C.递推算法通常用于穷举所有可能的解决方案。

D.递推算法适用于在每一步做出局部最优选择以达到全局最优。

【答案】:B

【解析】

递推算法是从已知的基础情况出发,通过递推式推导出更大规模的解。

第11题

给定如下算法,其时间复杂度为( )。

bool f(int arr[], int n, int target) {for (int i=0; i<n; i++) {int sum = 0;for (int j = 0; j<n; j++) {if (i & (1 << j)) {sum += arr[j];}}if (sum == target) return true;}return false;
}

A.\(O(n)\)

B.\(O(n^2)\)

C.\(O(n^3)\)

D.\(O(2^n)\)

【答案】:B

【解析】

代码中双重循环都是循环n次,且没有break操作,复复杂度为\(O(n²)\)

第12题

下述斐波那契数列计算的时间复杂度是( )。

int fibonacci(int n) {if (n == 0) return 0;if (n == 1) return 1;return fibonacci(n-1) + fibonacci(n-2);
}

A.\(O(n)\)

B.\(O(n^2)\)

C.\(O(n^3)\)

D.\(O(2^n)\)

【答案】:D

【解析】

使用递归实现斐波那契数的计算,可以发现每次递归都会调用两次函数,一共有n层调用,那么总共的时间复杂度是\(O(2^n)\)

第13题

关于下面 C++ 程序的描述,( )最准确。

ifstream in("data.txt");
string line;
while (getline(in, line)) {cout << line << endl;
}

A.将从标准输入读取每行,并输出到屏幕

B.程序无法运行,因为 getline 只能读取 cin

C.将 data.txt 中的每一行读取并输出到屏幕

D.程序将创建 data.txt 并写入默认文本

【答案】:C

【解析】

注意到第一行定义了一个文件输入流in指向了“data.txt”文件,因此这里输入是从文件中输入,然后输出是使用标准输出流cout,因此是从文件中输入每一行输出到屏幕上。

第14题

在C++中,异常处理机制(try-catch块)的主要目的是( )。

A.提高程序的运行速度。

B.在程序发生运行时错误时,提供一种结构化的错误处理方式。

C.确保程序在编译时没有错误。

D.减少程序的内存占用。

【答案】:B

【解析】

异常处理机制的核心目的是在程序运行时发生错误(如除零错误、内存分配失败等)时,提供一种结构化且优雅的方式来捕获和处理这些错误,从而避免程序崩溃并提高程序的健壮性。

第15题

为了提高冒泡排序的效率,如果某轮“冒泡”中没有执行任何交换操作,说明数组已经完成排序,可直接返 回结果,则两条横线上分别应该填写( )。

void bubbleSortWithFlag(vector<int> &nums) {for (int i=nums.size()-1; i>0; i--) {bool flag;______  // 在此处填入代码for (int j=0; j<i; j++) {if (nums[j] > nums[j+1]) {swap(nums[j], nums[j+1];______  // 在此处填入代码}}if (!flag)break;}
}

A.

flag = false;
flag = false;

B.

flag = false;
flag = true;

C.

flag = true;
flag = false;

D.

flag = true;
flag = true;

【答案】:B

【解析】

题目要求没有发生交换操作则结束程序,那么根据第12行的break语句可知,当flag变量为false时,表示没有发生交换操作,相对应的第9行为发生了交换操作,应该将flag改为true,初始值应该设为false,选择B。

判断题

第16题

下面C++代码正确声明了一个返回 int 类型、接受两个 int 参数的函数。

int add(int, int);

A.正确

B.错误

【答案】:A

【解析】

函数声明的格式为:

返回值类型
函数名
参数列表(包括参数类型和个数)

在该题中,int add(int, int); 正确声明了一个函数:

返回值类型为int。
函数名为add。
参数列表中有两个 int 类型的参数。

第17题

下面C++代码的输出是 15 。

void foo(int x) {x += 5;
}
int main() {int a = 10;foo(a);cout << a << endl;
}

A.正确

B.错误

【答案】:B

【解析】

该代码的参数传递方式为值传递,不会改变实参的值,输出还是10

第18题

下面c++代码在一个结构体中又定义了别的结构体。这种结构嵌套定义的方式语法不正确。

#include <string>
#include <vector>using namespace std;struct Library {struct Book {struct Author {string name;int birthYear;};string title;int year;Author author;};string name;vector<Book> books;
};

A.正确

B.错误

【答案】:B

【解析】

结构体定义成员时,成员可以是结构体类型,完全可以进行结构体嵌套。

第19题

在C++中,相比于值传递,使用引用传递作的优点可以直接操作和修改原始变量,避免数据拷贝,提高效 率。

A.正确

B.错误

【答案】:A

【解析】

值传递不会改变实参的值,会进行一次拷贝操作。引用传递会改变实参的值,避免了数据拷贝。

第20题

下面这段代码不合法,因为每一行都必须显式初始化 3 个元素。

int arr[2][3] = {{1,2},{3}};

A.正确

B.错误

【答案】:B

【解析】

这里初始化了第一行的前2个元素,第二行的前1个元素,可以不用将所有元素都初始化。

第21题

以下程序中使用了递推方式计算阶乘( ),计算结果正确。

int factorial(int n) {int res = 1;for (int i=0; i<n; ++i) {res *= i;}return res;
}

A.正确

B.错误

【答案】:B

【解析】

计算阶乘应该从1开始计算,代码中从0开始计算,会导致最终结果均为0。

第22题

无论初始数组是否有序,选择排序都执行 \(O(n^2)\) 次比较

A.正确

B.错误

【答案】:A

【解析】

选择排序的思路为每次挑选最小值放到整个序列的最前方,选择最小值需要一个O(n)的复杂度,由于需要排序,需要选择n次最小值,则为 \(O(n²)\)

第23题

以下C++代码,尝试对有 n 个整数的数组 arr 进行排序。这个代码实现了选择排序算法。

for (int i=0; i<n-1; ++i) {int minIndex = i;for (int j=i+1; j<n; ++j) {if (arr[j] < arr[minIndex])minIndex = j;}if (minIndex != i)swap(arr[i], arr[minIndex]);
}

A.正确

B.错误

【答案】:A

【解析】

选择排序的思路为每次挑选最小值放到整个序列的最前方,其中代码的36行为选择后面的最小值,78行为将最小值与前面的元素交换。

第24题

如果一个异常在 try 块中抛出但没有任何 catch 匹配,它将在编译时报错。

A.正确

B.错误

【答案】:B

【解析】

如果一个异常在 try 块中抛出但没有匹配的 catch块,程序不会在编译时报错,而是在运行时发生未处理的异常。未处理的异常会导致程序终止。这是运行时行为,而不是编译时错误。

第25题

下面C++代码实现将 Hello 写入 data.txt 。

ofstream out("data.txt");
out << "Hello";
out.close();

A.正确

B.错误

【答案】:A

【解析】

ofstream 是C++中用于文件输出的流类,通过它可以将数据写入文件。

out << ”Hello”; 将字符串 Hello 写入到 data.txt 文件中。

out.close(); 用于关闭文件流,确保数据成功写入并释放资源。

编程题

B4360 画布裁剪

【题目来源】

洛谷:B4360 [GESP202506 四级] 画布裁剪 - 洛谷

【题目描述】

小 A 在高为 \(h\) 宽为 \(w\) 的矩形画布上绘制了一幅画。由于画布边缘留白太多,小 A 想适当地裁剪画布,只保留画的主体。具体来说,画布可以视为 \(h\)\(w\) 列的字符矩阵,其中的字符均为 ASCII 码位于 \(33∼126\) 之间的可见字符,小 A 只保留画布中由第 \(x_1\) 行到第 \(x_2\) 行、第 \(y_1\) 列到第 \(y_2\) 列构成的子矩阵。

小 A 将画布交给了你,你能帮他完成画布的裁剪吗?

【输入】

第一行,两个正整数 \(h,w\),分别表示画布的行数与列数。

第二行,四个正整数 \(x_1,x_2,y_1,y_2\),表示保留的行列边界。

接下来 \(h\) 行,每行一个长度为 \(w\) 的字符串,表示画布内容。

【输出】

输出共 \(x_2−x_1+1\) 行,每行一个长度为 \(y_2−y_1+1\) 的字符串,表示裁剪后的画布。

【输入样例】

3 5
2 2 2 4
.....
.>_<.
.....

【输出样例】

>_<

【算法标签】

《洛谷 B4360 画布剪裁》 #字符串(入门)# #GESP# #2025#

【代码详解】

#include <bits/stdc++.h>
using namespace std;const int N = 105;  // 定义网格最大尺寸int h, w;           // 网格的行数和列数
char a[N][N];       // 存储网格字符的二维数组
int x1, x2, y1, y2; // 定义要输出的子网格范围int main()
{// 输入网格的行数和列数cin >> h >> w;// 输入要输出的子网格范围(左上角和右下角坐标)cin >> x1 >> x2 >> y1 >> y2;// 输入网格数据for (int i = 1; i <= h; i++)for (int j = 1; j <= w; j++)cin >> a[i][j];// 输出指定子网格范围内的内容for (int i = x1; i <= x2; i++){for (int j = y1; j <= y2; j++)cout << a[i][j];  // 输出当前字符cout << endl;  // 每行结束后换行}return 0;
}

【运行结果】

3 5
2 2 2 4
.....
.>_<.
.....
> _ < 

B4361 排序

【题目来源】

洛谷:B4361 [GESP202506 四级] 排序 - 洛谷

【题目描述】

体育课上有 \(n\) 名同学排成一队,从前往后数第 \(i\) 位同学的身高为 \(h_i\),体重为 \(w_i\)。目前排成的队伍看起来参差不齐,老师希望同学们能按照身高从高到低的顺序排队,如果身高相同则按照体重从重到轻排序。在调整队伍时,每次只能交换相邻两位同学的位置。老师想知道,最少需要多少次交换操作,才能将队伍调整成目标顺序。

【输入】

第一行,一个正整数 \(n\),表示队伍人数。

接下来 \(n\) 行,每行两个正整数 \(h_i\)\(w_i\),分别表示第 \(i\) 位同学的身高和体重。

【输出】

输出一行,一个整数,表示最少需要的交换次数。

【输入样例】

5
1 60
3 70
2 80
4 55
4 50

【输出样例】

8

【算法标签】

《洛谷 B4361 排序》 #排序# #GESP# #2025#

【代码详解】

#include <bits/stdc++.h>
using namespace std;const int N = 3005;  // 定义最大数据量// 定义结构体存储高度和宽度
struct Node
{int h;  // 高度int w;  // 宽度
} a[N];    // 结构体数组int n;     // 物品数量
int cnt = 0; // 交换次数计数器int main()
{// 输入物品数量cin >> n;// 输入每个物品的高度和宽度for (int i = 1; i <= n; i++)cin >> a[i].h >> a[i].w;// 冒泡排序过程for (int i = 1; i <= n; i++){// 内层循环,每次减少比较范围for (int j = 1; j <= n - i; j++){// 如果前一个物品高度小于后一个,交换并计数if (a[j].h < a[j + 1].h){swap(a[j], a[j + 1]);cnt++;}// 高度相等时,比较宽度else if (a[j].h == a[j + 1].h && a[j].w < a[j + 1].w){swap(a[j], a[j + 1]);cnt++;}}}// 输出总交换次数cout << cnt << endl;return 0;
}

【运行结果】

5
1 60
3 70
2 80
4 55
4 50
8

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1174815.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

豆包写的论文怎么过AIGC检测?实测这几款工具有效 - 还在做实验的师兄

豆包生成的论文AI率通常在70%-90%,直接提交肯定过不了。推荐用嘎嘎降AI(85%→8%,4.8元/千字)或比话降AI(可降至5%以下)处理。让豆包自己改没用。豆包写的论文怎么过AIGC检测?实测这几款工具有效TL;DR:豆包生成…

GESP认证C++编程真题解析 | 202506 三级

​欢迎大家订阅我的专栏:算法题解:C++与Python实现! 本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战! 专栏特色 1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的…

Hitler the justice

I hate this world, only Heiliges Rmisches Reich gives me meaning. I love Deutschland and hate the bullies, because I can not find the common love.

DeepSeek写的论文怎么降AI率?3款工具实测对比 - 还在做实验的师兄

DeepSeek写的论文直接提交知网检测,AI率通常在38%-99%之间。单靠DeepSeek自己降AI效果有限(平均降35%),推荐用专业工具:嘎嘎降AI性价比高,比话降AI可将AI率降至0%。DeepSeek写的论文怎么降AI率?3款工具实测对比…

GESP认证C++编程真题解析 | 202506 一级

​欢迎大家订阅我的专栏:算法题解:C++与Python实现! 本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战! 专栏特色 1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的…

2026年期刊论文降AI率工具推荐,顺利发表必备 - 还在做实验的师兄

期刊对AI率的要求通常比学校更严格,部分期刊要求低于10%甚至5%。推荐比话降AI(可降至0%,8元/千字)和嘎嘎降AI(达标率99.26%,4.8元/千字)。投稿前一定要处理好AI率。2026年期刊论文降AI率工具推荐,顺利发表必备…

详细介绍:任务悬赏小程序核心玩法 + 功能全解析:精准匹配与信任构建的变现逻辑

详细介绍:任务悬赏小程序核心玩法 + 功能全解析:精准匹配与信任构建的变现逻辑pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-…

毕业论文降AI率,学长推荐的5款工具(含免费额度) - 还在做实验的师兄

毕业论文AIGC检测不过别慌,这5款降AI工具都有免费额度可以先体验。重点推荐嘎嘎降AI(免费试用+达标率99.26%)和比话降AI(500字免费+知网专精)。先免费测效果,满意再付费。毕业论文降AI率,学长推荐的5款工具(含…

GESP认证C++编程真题解析 | 202506 二级

​欢迎大家订阅我的专栏:算法题解:C++与Python实现! 本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战! 专栏特色 1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的…

基于SSM的服装销售系统-计算机毕业设计源码+无LW文档

基于SSM的服装销售系统论文 摘要&#xff1a;本文围绕基于SSM&#xff08;Spring、SpringMVC、MyBatis&#xff09;框架的服装销售系统展开研究。阐述了系统的研究背景与意义&#xff0c;深入分析系统需求&#xff0c;详细介绍功能设计。该系统旨在解决传统服装销售管理模式的问…

嘎嘎降AI vs 比话降AI:2026年降AI工具对比测评 - 还在做实验的师兄

嘎嘎降AI主打性价比(4.8元/千字,达标率99.26%),比话降AI主打知网专精(8元/千字,可降至0%)。追求省钱选嘎嘎,追求极致效果选比话。两款都很靠谱,按需选择即可。嘎嘎降AI vs 比话降AI:2026年降AI工具对比测评T…

大数据领域必备:ClickHouse 全方位解析

大数据领域必备&#xff1a;ClickHouse 全方位解析 一、引言 (Introduction) 钩子 (The Hook) “昨天凌晨3点&#xff0c;我被运维的电话叫醒——数据 dashboard 又崩了。” 这是我做大数据工程师时最难忘的经历。当时我们用Hive处理用户行为数据&#xff0c;每次业务方要查“过…

新能源汽车充电服务系统-计算机毕业设计源码+LW文档

一、 研究的背景、目的和意义 &#xff08;一&#xff09;课题研究的背景 随着新能源汽车市场的快速发展&#xff0c;充电服务成为关键环节。全球能源结构的转型是当前新能源汽车充电服务系统设计的重要背景之一。传统化石能源的消耗带来了严重的环境污染和温室气体排放&…

SCI论文降AI率工具推荐:Turnitin检测轻松过 - 还在做实验的师兄

SCI论文投稿前需要通过Turnitin AI检测,中文降AI工具对英文无效。推荐AIGCleaner(专业英文降AI,Turnitin检测83%→0%)。国内论文可用嘎嘎降AI配合。SCI论文降AI率工具推荐:Turnitin检测轻松过TL;DR:SCI论文投稿前…

JUC并发编程:LockSupport.park() 与 unpark() 深度解析

一、前言在Java并发编程中&#xff0c;AQS (AbstractQueuedSynchronizer) 是实现锁&#xff08;如 ReentrantLock&#xff09;、同步器&#xff08;如 CountDownLatch&#xff09;的核心基础。而 AQS 能够实现线程的阻塞与唤醒&#xff0c;其底层完全依赖于 LockSupport 工具类…

AIGC检测原理解析:为什么自己写的论文也会被判AI生成 - 还在做实验的师兄

AIGC检测系统识别的是「AI特征」而非「是否由AI生成」。规范的学术写作特征与AI特征高度重合,所以自己写的论文也可能被误判。解决方法是用嘎嘎降AI等专业工具处理,让文本「看起来更像人写的」。AIGC检测原理解析:为…

高校志愿服务管理系统-计算机毕业设计源码+无LW文档

摘要&#xff1a;本文旨在探讨高校志愿服务管理系统的开发与实施。通过分析当前高校志愿服务管理的现状和存在的问题&#xff0c;提出了开发一个综合性的志愿服务管理系统的需求。本文详细阐述了系统的需求分析、功能设计以及预期的社会和经济影响&#xff0c;旨在提高高校志愿…

论文AI率从90%降到5%,我用了这个方法 - 还在做实验的师兄

AI率90%是极高的情况,但专业工具可以处理。我用嘎嘎降AI把90%的AI率降到了5%以下,花了不到50块钱,全程20分钟。手动改根本不可能,直接用工具是唯一出路。论文AI率从90%降到5%,我用了这个方法TL;DR:AI率90%是极高…

2026年便宜好用的降AI工具推荐,学生党必看 - 还在做实验的师兄

学生党预算有限,推荐嘎嘎降AI(4.8元/千字,1000字免费试用)和率零(3.2元/千字,最便宜)。效果要求高选嘎嘎,纯省钱选率零。都有免费额度,先试再买。2026年便宜好用的降AI工具推荐,学生党必看TL;DR:学生党预算…

2026年降AI工具年度盘点:哪款最值得用 - 还在做实验的师兄

2026年降AI工具年度盘点:性价比之王是嘎嘎降AI(4.8元/千字,达标率99.26%),效果极致是比话降AI(8元/千字,可降至0%),最便宜是率零(3.2元/千字)。按需选择即可。2026年降AI工具年度盘点:哪款最值得用TL;DR:…