您的位置:首页 > 健康 > 养生 > 石家庄网站建设策略_职高的电子商务主要学什么_还有哪些平台能免费营销产品_流量推广怎么做

石家庄网站建设策略_职高的电子商务主要学什么_还有哪些平台能免费营销产品_流量推广怎么做

2025/1/8 11:03:26 来源:https://blog.csdn.net/m0_56456270/article/details/144723977  浏览:    关键词:石家庄网站建设策略_职高的电子商务主要学什么_还有哪些平台能免费营销产品_流量推广怎么做
石家庄网站建设策略_职高的电子商务主要学什么_还有哪些平台能免费营销产品_流量推广怎么做

一、单选题(每题2分,共30分)

题目123456789101112131415
答案

A

B

D

C

C

C

A

B

A

A

D

A

C

B

B

1.下面有关函数参数的说法,正确的是( )。
A. 函数参数传递时,主函数当中采用值传递方式将参数传递给子函数时,若子函数将参数值改变,主函数当中

的参数值不变。

B. 函数参数传递时,主函数当中采用值传递方式将参数传递给子函数时,若子函数将参数值改变,主函数当中

的参数值将随子函数一样改变而改变。

C. 函数参数传递时,主函数如果将参数的地址传递给子函数,若子函数将参数值改变,主函数当中的参数值将

不改变。

D. 函数参数传递可以不满足子函数的参数个数要求。

【答案】A

【考纲知识点】函数参数传递方式(值传递和地址传递)

【解析】在函数参数传递中,值传递是将实参的值复制一份传递给形参,形参的修改不会影响到实参的值。所以选项 A 正确,选项 B 错误。

地址传递是将实参的地址传递给形参,通过形参修改地址所指向的值,会影响到实参的值。选项 C 中,主函数将参数的地址传递给子函数,若子函数通过地址修改了参数值,主函数当中的参数值会改变,所以选项 C 错误。

函数参数传递必须满足子函数的参数个数要求,否则会导致错误,选项 D 错误。

2.下面C++代码执行后,输出的是( )。
int arr[10]={1};

string strArr="chen a dai";

cout<<strArr[arr[1]]<<endl;

A. chen

B. c

C. chen a dai

D. dai

【答案】B

【考纲知识点】数组、字符串的操作

【解析】首先,arr[1]的值为 0 (因为数组 arr 初始化时只有第一个元素为 1,其他元素为 0)。

然后,strArr[arr[1]] 即 strArr[0] ,也就是字符串 strArr 的第一个字符 'c' 。所以输出的是 'c' ,选择选项 B 。

3.下面C++代码最后执行后输出是( )。
int fun1(int *n)

{

return *n**n;

}

int main()

{

int arr[10]={2};

arr[1]=fun1(arr);

cout<<arr[1]<<endl;

}
A. 1

B. 2
C. 3

D. 4

【答案】D

【考纲知识点】指针、函数调用

【解析】在 fun1 函数中,传入的是一个整数指针 n ,函数返回 *n * *n 的值。

在 main 函数中,首先定义了整数数组 arr 并初始化第一个元素为 2。然后调用 fun1(arr) ,此时 *n 的值为 2(因为 arr 的第一个元素为 2),*n * *n 即 2 * 2 = 4 ,并将这个值赋给 arr[1] 。

最后输出 arr[1] 的值,即为 4 ,选择选项 D 。

4.下面C++代码执行后的结果是( )。
int arr[3][3]={{1,2,3},{4,5,6},{7,8,9}};

for(int i=0;i<3;i++){

for(int j=2;j>=0;j--){

cout<<arr[i][j]<<" ";

}

cout<<endl;

}

A. 
1 2 3
4 5 6
7 8 9

B.
1 2 3 4 5 6 7 8 9

C.
3 2 1
6 5 4
9 8 7

D.
9 8 7 6 5 4 3 2 1

【答案】C

【考纲知识点】二维数组、循环

【解析】这段代码是对一个 3×3 的二维数组进行遍历输出。外层循环控制行数,内层循环控制列数。但是内层循环是从 2 到 0 进行遍历,所以输出的是每一行的元素从后往前,即先输出第 3 列,再输出第 2 列,最后输出第 1 列。

所以输出结果为:

3 2 1

6 5 4

9 8 7

选择选项 C。

5.下面C++代码执行后输出是( )。
int arr[3]={1,2,3};

int *p=NULL;

p=arr;

p++;

cout<<*p<<endl;



A. 1,2,3

B. 1

C. 2

D. 3
【答案】C

【考纲知识点】指针操作、数组与指针的关系

【解析】首先,定义了一个整数数组 arr ,并将指针 p 初始化为 NULL 。然后,让 p 指向数组 arr 。

由于数组在内存中是连续存储的,当 p 指向 arr 后,p++ 会使 p 指向数组的下一个元素。

数组 arr 中,第一个元素是 1 ,所以 p++ 后,*p 指向的是 2 。

因此,输出的是 2 ,选择选项 C 。

6.如果变量x的地址是0x6ffe14,下面C++代码执行以后输出的是( )。
int *p=NULL;

int x=2;

p=&x;

p++;

cout<<p<<endl;

A. 0x6ffe11

B. 0x6ffe14

C. 0x6ffe18

D. 0x6ffe15

【答案】C

【考纲知识点】指针的运算和内存地址的理解。

【解析】在这段 C++ 代码中,首先定义了一个空指针 p 。接着定义了整数变量 x 并获取其地址赋值给 p 。由于 p 是 int* 类型的指针,而在大多数系统中,int 类型占用 4 个字节的内存空间。当执行 p++ 操作时,p 所指向的地址会按照 4 个字节的步长增加。初始时 x 的地址为 0x6ffe14 ,增加 4 个字节后,地址就变成了 0x6ffe18 ,所以最终输出的是 0x6ffe18 ,答案选择 C 选项。

7.在C++中,执行下面代码后,输出的是( )。
int point(int *p)

{

return *p**p;

}

int main()

{

int a=20;

int *p=&a;

*p=point(p);

cout<<*p<<endl;

}

A. 400

B. 200

C. 20

D. 100

【答案】A

【考纲知识点】函数参数传递、指针的运用。

【解析】在 point 函数中,接收一个 int* 类型的指针参数 p ,函数返回 *p * *p 的值。

在 main 函数中,定义了整数 a 并初始化为 20,然后定义指针 p 指向 a 。

接下来调用 point 函数并将 p 作为参数传递进去。在函数内部,*p 就是 a 的值 20,*p * *p 即 20 * 20 = 400 。

然后将这个结果赋值给 *p ,也就是改变了 a 的值为 400 。

最后输出 *p ,也就是 a 的值,所以输出为 400 ,答案选择 A 选项。

8.下列C++语句执行以后结果是true的是( )。
A. 3&&false

B. 5&&2

C. 101&&000

D. 4&true

【答案】B

【考纲知识点】逻辑与运算(&&)的规则。

【解析】在 C++ 中,逻辑与运算(&&)只有当两边的操作数都为非零值时,结果才为 true 。

选项 A 中,false 为 0 ,所以 3 && false 的结果为 false 。

选项 B 中,5 和 2 都是非零值,所以 5 && 2 的结果为 true 。

选项 C 中,101 和 000 不是 C++ 中合法的逻辑表达式形式。

选项 D 中,4 是整数,true 不是合法的能与之直接进行逻辑与运算的操作数。

综上所述,结果为 true 的是选项 B 。

9.在如下的C++代码中实现了对字符串中出现的26个字母的个数统计,横线处应填入是( )。
string str="HELLO CHEN A DAI";

int strlen=

str.length();

char alpha[26]={65};

int cnt[26]={e};

for(int i=i;i<26;i+)

{

____________;

}

for(int i=e;i<26;i++)

{

cout<<alpha[i] <" ";

}

cout<<endl;

for(int i=8;i<26;i++)

{

for(int j=8;jcstrlen;j++)

{

if(alpha[i]==str[j])

{

cnt[i]++;

}

}

}

for(int i=8;i<26;i++)

{

cout<<cnt[i] <" ";

}

A. alpha[i]=alpha[i-1]+1;

B. alpha[i]=alpha[i]+1;

C. alpha[i+1]=alpha[i]+1;

D. alpha[i-1]=alpha[i]+1;

【答案】A

【考纲知识点】字符数组操作、循环遍历。

【解析】在这段代码中,目的是统计字符串中 26 个字母出现的个数。

首先,我们需要初始化一个包含 26 个字母的字符数组 alpha 。

选项 A 中,alpha[i] = alpha[i - 1] + 1; 能够依次将 alpha 数组中的元素初始化为连续的大写字母。从 alpha[0] = 65(即 'A')开始,通过这个赋值语句,alpha[1] 会被初始化为 66(即 'B'),以此类推,直到 alpha[25] 为 'Z'。

选项 B 中,alpha[i] = alpha[i] + 1; 没有明确的初始值,无法正确初始化字母序列。

选项 C 中,alpha[i + 1] = alpha[i] + 1; 不符合顺序初始化的要求,会导致初始化错误。

选项 D 中,alpha[i - 1] = alpha[i] + 1; 也不符合顺序初始化的逻辑。

综上所述,横线处应填入选项 A,才能正确初始化字母数组,以便后续进行字母出现个数的统计。

10.下面C++代码执行后生成的文件其字节数为( )。
ofstream fout;

fout.open("1.txt");

for(int i=1;i<=10;i++){

if(i%5==0){

int x=6;

fout<<x;

}

else

{

char ch='A';

fout<<ch;

}

}

A. 10

B. 16

C. 40

D. 24

【答案】A

【考纲知识点】文件操作、数据类型的存储大小。

【解析】在这个代码中,循环 10 次。

当 i % 5 == 0 时,写入一个整数 6 ,在文件中通常整数占用 4 个字节。

当 i % 5!= 0 时,写入一个字符 'A' ,字符在文件中通常占用 1 个字节。

但是,由于题目中每次写入后没有换行或添加其他分隔符,所以文件中的内容是紧凑存储的。

总共写入了 10 个数据,所以文件的字节数为 10 。答案选择 A 选项。

11.下列C++代码输入 1,2,3,4 ,执行后,将输出的是( )。
string str="";

cin>>str;

int strlen=str.length();

for(int i=0;i<strlen;i++){

if(str[i]<='9'&&str[i]>='0'){

cout<<str[i];

}

else{

cout<<"#";

}

}

A. 1#4#

B. 1#3#

C. 1#2#3#4#

D. 1#2#3#4

【答案】D

【考纲知识点】字符串处理、条件判断。

【解析】首先,用户输入 1,2,3,4 ,但 cin >> str 会把它当作一个字符串来处理,所以 str 的值为 "1,2,3,4" 。

然后,通过循环遍历字符串 str 。

对于每个字符,如果它在 '0' 到 '9' 之间,就直接输出该字符;否则,输出 '#' 。

在 "1,2,3,4" 中,1、2、3、4 满足条件直接输出,而逗号不满足条件输出 '#' 。

但由于没有在每次输出后添加换行符,所以最终的输出是 1#2#3#4 ,答案选择 D 选项。

12.以下C++代码用于实现每个整数对应的因数,如输入 12 ,则输出 1 2 3 4 6 12 ;如输入 18 ,则输出 1 2 3 6 9 18 。横线处应填入代码是( )。
int n;

cin>>n;

for(int i=1;i<=n;i++){

__________

{

cout<<i<<" ";

}

}
A. if(n%i==0)
B. if(n/i==0)

C. if(n%i!=0)

D. if(n/i!=0)

【答案】A

【考纲知识点】循环、取余运算、条件判断。

【解析】在这段代码中,我们需要找出能整除输入整数 n 的数,也就是 n 的因数。

取余运算 n % i 表示 n 除以 i 的余数。当 n % i == 0 时,说明 i 能够整除 n,i 就是 n 的因数。

选项 A 中,if (n % i == 0) 能够正确判断 i 是否为 n 的因数,如果是,则输出 i 。

选项 B 中,n / i 是除法运算的结果,判断 n / i == 0 通常不符合我们找因数的逻辑。

选项 C 中,if (n % i!= 0) 是判断 i 不是 n 的因数,不符合我们要输出因数的要求。

选项 D 中,同样 n / i!= 0 不符合找因数的逻辑。

综上所述,横线处应填入选项 A ,才能正确找出并输出 n 的因数。

13.某公司新出了一款无人驾驶的小汽车,通过声控智能驾驶系统,乘客只要告诉汽车目的地,车子就能自动选择一条优化路线,告诉乘客后驶达那里。请问下面哪项不是驾驶系统完成选路所必须的。( )

A. 麦克风

B. 扬声器

C. 油量表

D. 传感器

【答案】C

【考纲知识点】无人驾驶系统的组成和功能。

【解析】对于无人驾驶汽车的声控智能驾驶系统,完成选路需要以下几个关键部分:

选项 A 中的麦克风用于接收乘客输入的目的地语音指令。

选项 B 中的扬声器可以用来向乘客反馈路线信息等。

选项 D 中的传感器用于感知车辆周围的环境和路况,为路线选择提供重要的数据支持。

而选项 C 中的油量表主要是用于显示车辆燃油的余量,它对于路线的选择并不是必需的。

所以,不是驾驶系统完成选路所必须的是选项 C 。

14.现代计算机是指电子计算机,它所基于的是( )体系结构。

A. 艾伦·图灵

B. 冯·诺依曼

C. 阿塔纳索夫

D. 埃克特-莫克利

【答案】B

【考纲知识点】计算机体系结构的发展。

【解析】现代电子计算机所基于的是冯・诺依曼体系结构。

冯・诺依曼体系结构具有以下特点:

1.计算机由运算器、控制器、存储器、输入设备和输出设备五大部分组成。

2.指令和数据以同等地位存储在存储器中,并可按地址寻访。

3.指令和数据均用二进制表示。

4.指令由操作码和地址码组成,操作码用来表示操作的性质,地址码用来表示操5.作数在存储器中的位置。

6.指令在存储器内按顺序存放。

7.机器以运算器为中心,输入输出设备与存储器间的数据传送通过运算器完成。

正是由于冯・诺依曼体系结构的这些特点,奠定了现代电子计算机的基础。

所以这道题选择 B 选项。

15.输入一个正整数N(N>=7),想找出它所有相邻的因数对,比如,输入12,因数对有(1,2)、(2,3)、(3.4)。下面哪段代码找不到所有的因数对?()

A. for(i=1;i<N;i++) if(!(N%i) && !(N%(i+1))) printf("(%d,%d)\n", i, i+1);

B. for(i=2;i<N;i++) if(!(N%i) && !(N%(i+1))) printf("(%d,%d)\n", i, i+1);

C. for(i=2;i<N/2;i++) if(!(N%(i-1)) && !(N%i)) printf("(%d,%d)\n", i-1, i);

D. for(i=1;i<N/2;i++) if(!(N%i) && !(N%(i+1))) printf("(%d,%d)\n", i, i+1);
【答案】B

【考纲知识点】循环、取余运算、因数的判断。

【解析】首先分析选项 A,从 1 开始循环到 N - 1 ,对于每个 i ,判断 i 和 i + 1 是否都是 N 的因数,如果是则输出因数对。这样能全面地检查所有可能的相邻因数对。

选项 B 从 2 开始循环,会遗漏 1 和 2 这种可能的相邻因数对。

选项 C 从 2 开始循环到 N / 2 ,对于每个 i ,判断 i - 1 和 i 是否都是 N 的因数,如果是则输出因数对。能找到一部分相邻因数对,但起始位置不是从 1 开始,可能会遗漏某些情况。

选项 D 从 1 开始循环到 N / 2 ,对于每个 i ,判断 i 和 i + 1 是否都是 N 的因数,如果是则输出因数对。能找到大部分相邻因数对,但可能会遗漏 N 较大时后半部分的相邻因数对。

综上所述,选项 B 因为从 2 开始循环,不能找到所有的相邻因数对。所以这道题选择 B 选项。

二、判断题(每题2分,共20分)

题目12345678910
答案

×

×

×

×

1.C++的内置函数 sort() 支持数组的局部排序。例如 int a={10,9,8,7,6,5,4,3,2,1} ,可以用sort(a,a+5) ,排序成 {6,7,8,9,10,5,4,3,2,1} 。( )

【答案】√

【考纲知识点】C++ 标准库函数 sort () 的用法。

【解析】在 C++ 中,sort () 函数可以对指定范围内的元素进行排序。

当使用 sort (a, a + 5) 时,它会对数组 a 的前 5 个元素(即 a [0] 到 a [4] )进行排序。

在给定的例子中,原本的数组是 {10, 9, 8, 7, 6, 5, 4, 3, 2, 1} ,经过 sort (a, a + 5) 操作后,前 5 个元素会被排序为 {6, 7, 8, 9, 10} ,而后面的元素保持不变,最终得到 {6, 7, 8, 9, 10, 5, 4, 3, 2, 1} 。

所以该说法是正确的。

2.用递归法求n的阶乘,时间复杂度是O(n)。

【答案】√

【考纲知识点】递归算法的时间复杂度分析。

【解析】在使用递归法计算 n 的阶乘时,递归函数会重复调用自身 n 次,每次调用都进行一些固定的操作,因此时间复杂度与 n 成正比,即为 O (n) 。

具体来说,每次递归调用都会执行一些基本的计算和判断操作,这些操作的执行次数与 n 呈线性关系,所以总的时间复杂度是 O (n) 。

3.[(1,2)*2]*3 在C++中是合法的表达式。( )

【答案】×

【考纲知识点】C++ 表达式的合法性。

【解析】在 C++ 中,(1, 2) 这种形式不是一个合法的操作。通常在 C++ 中,我们使用括号来改变运算的优先级或者表示函数的参数等,但 (1, 2) 这种形式不符合常见的合法表达式的结构。

所以 [(1, 2) * 2] * 3 不是合法的 C++ 表达式。

因此这道题的答案是 ×。

4.在下面的C++代码中,将对1.txt文件写入 hello 。( )
ifstream filein;

ofstream fileout;

filein.open("1.txt");

fileout<<"hello";

【答案】×

【考纲知识点】文件输入输出流的使用。

【解析】在这段 C++ 代码中,ifstream 用于文件的读取操作,而 ofstream 才用于文件的写入操作。

但是这里使用了 ifstream 对象 filein 来尝试打开文件并进行写入操作,这是错误的。应该使用 ofstream 对象 fileout 来执行写入操作。

所以这段代码无法对 “1.txt” 文件写入 “hello”,答案为 ×。

5.文本文件 1.txt 第1行由 01234 共5个字符组成其间没有空格,当用C++代码正常打开文件成功并执行如下代码以后,第1行长度为5( )
ifstream filein;

int buff;

filein.open("1.txt");

filein>>buff;

cout<<buff<<endl;

【答案】×

【考纲知识点】文件输入流和数据类型转换。

【解析】在这段 C++ 代码中,使用 ifstream 从文件读取数据。

当使用 >> 操作符从文件读取数据到 int 类型的 buff 变量时,它会尝试将读取到的字符转换为整数。

对于文本文件中的 "01234" ,它会把遇到的第一个非数字字符之前的数字部分转换为整数,也就是只读取 "0" 并转换为整数 0 。

所以读取后 buff 的值为 0 ,而不是认为这一行的长度为 5 。

因此答案是 ×。

6.执行C++代码 cout<<(5||2); 后将输出 1 。( )

【答案】√

【考纲知识点】逻辑或运算的结果和输出。

【解析】在 C++ 中,逻辑或运算符 || 只要其中一个操作数为真(非零值),整个表达式就为真。

在表达式 (5 || 2) 中,因为 5 是非零值,所以整个表达式为真。

在 C++ 中,输出布尔值为真时,通常会输出 1 。

所以执行 cout << (5 || 2); 后将输出 1 ,答案是√。

7.在C++中,两个字符串相加的运算符为+相当于字符串的合并运算。下面C++代码执行后,将输出chenadai 。( )
string a="chen";

string b="a";

string c="dai";

string name=a+b+c;

cout<<name<<endl;

【答案】√

【考纲知识点】C++ 中字符串的操作。

【解析】在 C++ 的标准库 <string> 中,字符串支持 + 运算符进行拼接操作。

在这段代码中,首先定义了三个字符串 a 、 b 和 c ,分别为 "chen" 、 "a" 和 "dai" 。

然后通过 string name = a + b + c; ,将这三个字符串依次拼接起来,得到 "chenadai" 。

最后使用 cout << name << endl; 输出拼接后的字符串,结果就是 "chenadai" 。

所以这道题的答案是√

8.C++内置函数 sort() 可以对整数、浮点数、字符数组进行从大到小,从小到大,局部排序。( )

【答案】√

【考纲知识点】C++ 内置函数 sort () 的功能和应用。

【解析】在 C++ 中,sort () 函数具有很强的通用性。

对于整数类型,它可以按照默认的升序(从小到大)进行排序,也可以通过自定义比较函数实现降序(从大到小)排序。

对于浮点数类型,同样可以实现升序和降序的排序。

对于字符数组,它会依据字符的 ASCII 码值进行排序,也能通过自定义比较规则实现特定的排序顺序。

而且,sort () 函数还支持对数组的局部进行排序。

所以,这道题的答案是√。

9.小杨最近在准备考GESP,他用的Dev C++来练习和运行程序,所以Dev C++也是一个小型操作系统。( )

【答案】×

【考纲知识点】操作系统与编程工具的区别。

【解析】Dev C++ 不是操作系统,而是一个集成开发环境(IDE)。

操作系统是管理计算机硬件与软件资源的程序,它负责控制和协调计算机的各种活动,为用户和应用程序提供一个运行环境。

而 Dev C++ 是为了方便程序员编写、编译、调试 C++ 程序而设计的工具,它运行在操作系统之上,依赖操作系统提供的资源和服务。

所以这道题答案是 ×。

10.任何一个while循环都可以转化为等价的for循环( )。

【答案】√

【考纲知识点】while 循环和 for 循环的结构和转换。

【解析】while 循环的基本结构是 “while (条件) { 循环体 }”,它只要条件为真就执行循环体。

for 循环的基本结构是 “for (初始化;条件;迭代) { 循环体 }”。

for 循环中的初始化部分可以用于设置循环的初始状态,条件部分用于判断是否继续循环,迭代部分用于在每次循环结束后更新循环变量。

对于任何一个 while 循环,我们都可以通过以下方式将其转换为等价的 for 循环:

将 while 循环的条件直接作为 for 循环的条件。

将 while 循环之前设置初始状态的代码放到 for 循环的初始化部分。

将 while 循环中更新循环变量的代码放到 for 循环的迭代部分。

所以,任何一个 while 循环都可以转化为等价的 for 循环,这道题答案是√。

三、编程题(每题25分,共50分)
 

1、小杨的字典

【问题描述】

在遥远的星球,有两个国家 A 国和 B 国,他们使用着不同的语言:A 语言和 B 语言。小杨是 B 国的翻译官,他的工作是将 A 语言的文章翻译成 B 语言的文章。

为了顺利完成工作,小杨制作了一本字典,里面记录了 个 A 语言单词对应的 B 语言单词,巧合的是,这些单词都由地球上的 26 个小写英文字母组成。

小杨希望你写一个程序,帮助他根据这本字典翻译一段 A 语言文章。这段文章由标点符号 !()-[]{}\|;:'",./?<> 和一些 A 语言单词构成,每个单词之间必定由至少一个标点符号分割,你的程序需要把这段话中的所有 A 语言单词替换成它的 B 语言翻译。特别地,如果遇到不在字典中的单词,请使用大写 UNK 来替换它。

例如,小杨的字典中包含 2 个 A 语言单词 abc 和 d ,它们的 B 语言翻译分别为 a 和 def ,那么我们可以把 A语言文章 abc.d.d.abc.abcd. 翻译成 B 语言文章 a.def.def.a.UNK. ,其中,单词 abcd 不在词典内,因此我们需要使用 UNK 来替换它。

【输入描述】

第一行一个整数 ,表示词典中的条目数。

接下来N行,每行两个用单个空格隔开的字符串A,B,分别表示字典中的一个 A 语言单词以及它对应的 B 语言翻译。最后一行一个字符串S,表示需要翻译的 A 语言文章。

【输出描述】

输出一行,表示翻译后的结果。

【样例输入 1】

2

abc a

d def

abc.d.d.abc.abcd.

【样例输出 1】

a.def.def.a.UNK.

【样例输入 2】

3

abc a

d def

abcd xxxx

abc,(d)d!-abc?abcd

【样例输出 2】

a,(def)def!-a?xxxx
【样例输入 3】
1

abcdefghij klmnopqrst

!()-[]{}\|;:'",./?<>abcdefghijklmnopqrstuvwxyz
【样例输入 3】
!()-[]{}\|;:'",./?<>UNK



【题目大意】

给定一个字典,其中包含 A 语言单词及其对应的 B 语言翻译,然后输入一段 A 语言文章,要求将文章中的 A 语言单词根据字典翻译成 B 语言,未在字典中的单词用 UNK 替换。

【考纲知识点】
数据结构:使用 map 存储字典。

字符串处理:对输入的文章进行字符遍历和单词识别。

【解题思路】

1.首先读取字典的条目数 N ,并构建一个 map 来存储 A 语言单词和其对应的 B 语言翻译。

2.读取要翻译的文章内容,通过遍历字符来识别单词。

3.当遇到字母时,将其累加到当前单词 word 中。

4.遇到非字母字符时,如果当前单词不为空,判断其是否在字典中,若在则输出对应的翻译,否则输出 UNK,然后清空当前单词,并输出当前的非字母字符。
【参考程序解析】
首先定义了一个 map 来存储字典的映射关系。

在 main 函数中,先读取字典条目数 N ,然后通过循环读取每个单词及其翻译并存储到 dict 中。

接着读取文章内容到 content ,并添加一个换行符方便处理。

通过一个循环遍历文章的每个字符,根据字符类型进行处理,实现单词的识别和翻译输出。

【参考程序】
#include <cstdio>

#include <cstdlib>

#include <cstring>

#include <algorithm>

#include <string>

#include <map>

#include <iostream>

using namespace std;

map<string, string> dict;

int main() {

int N;

cin >> N;

while(N --) {

string word1, word2;

cin >> word1 >> word2;

dict[word1] = word2;

}

string content, word = "";

cin >> content, content += "\n";

int m = content.length();

for(int i = 0; i < m; i ++) {

if (content[i] >= 'a' && content[i] <= 'z')

word += content[i];

else {

if (word != "") {

if (dict.count(word))

cout << dict[word];

else cout << "UNK";

word = "";

}

cout << content[i];

}

}

return 0;

}

2、田忌赛马

【问题描述】

你要和田忌赛马。你们各自有N匹马,并且要进行N轮比赛,每轮比赛,你们都要各派出一匹马决出胜负。

你的马匹的速度分别为u1,u2,u3...uN,田忌的马匹的速度分别为u1,u2,u3...uN 。田忌会按顺序派出他的马匹,请问

你要如何排兵布阵,才能赢得最多轮次的比赛?巧合的是,你和田忌的所有马匹的速度两两不同,因此不可能出现

平局。

【输入描述】

第一行一个整数N。

接下来一行N个用空格隔开的整数,依次为u1,u2,u3...uN ,表示你的马匹们的速度。接下来一行N 个用空格隔开的整数,依次为u1,u2,u3...uN ,表示田忌的马匹们的速度。保证 。

【输出描述】

输出一行,表示你最多能获胜几轮。

【样例输入 1】

3

1 3 5

2 4 6

【样例输出 1】

2

【样例输入 2】

5

10 3 5 8 7

4 6 1 2 9

【样例输出 2】
5

【题目大意】

给定你和田忌各自拥有的 N 匹马的速度,要求安排你的马匹出场顺序,使得在与田忌按顺序派出的马匹比赛中获胜轮次最多。所有马匹速度两两不同,无平局。

【考纲知识点】
排序算法

贪心算法

【解题思路】

首先对双方马匹的速度进行排序。然后从你的速度最快的马开始,依次与田忌当前速度最快的马比较,如果你的马速度更快,就赢得这一轮比赛,并且田忌派出下一匹速度次快的马;如果你的马速度慢,就直接放弃这一轮,田忌仍派出当前速度最快的马。通过这种贪心策略,统计赢得的轮次数。
【参考程序解析】
程序首先读取马匹数量 n 以及双方马匹的速度。

然后对双方马匹速度数组进行排序。

通过一个循环,比较双方当前速度最快的马,根据比较结果更新获胜轮次和田忌下一轮派出的马匹索引。

最后输出最多获胜的轮次数。




【参考程序】
#include <bits/stdc++.h>

using namespace std;

const int N = 100005;

int a[N], t;

int b[N], h;

int n;

int main() {

scanf("%d", &n);

for (int i = 1; i <= n; ++i) {

scanf("%d", &a[i]);

}

for (int i = 1; i <= n; ++i) {

scanf("%d", &b[i]);

}

h = 1;

t = 0;

sort(a + 1, a + n + 1);

sort(b + 1, b + n + 1);

int ans = 0;

for (int i = 1; i <= n; ++i)

if (a[i] > b[h])

++ans, ++h;

printf("%d\n", ans);

return 0;

}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com