2026.2.20——OJ92-94题

T92:字符串统计------字符串

代码实现:

#include <iostream>

#include <string>

using namespace std;

int main(){

string s1,s2;

bool firstgroup=true;

while(cin>>s1>>s2){

if(!firstgroup){

cout<<endl;

}

firstgroup=false;

//标记字母是否出现在s1和s2中

bool ins1[26]={false};

bool ins2[26]={false};

for(char c:s1)ins1[c-'a']=true;//s1中出现的字符,对应位置标为true

for(char c:s2)ins2[c-'a']=true;//s2中出现的字符,对应位置标为true

//存放四种结果

string orstr,andstr,xorstr,notstr;

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

char ch='a'+i;

if(ins1[i]||ins2[i]) orstr.push_back(ch);

if(ins1[i]&&ins2[i]) andstr.push_back(ch);

if(ins1[i]!=ins2[i]) xorstr.push_back(ch);

if(!ins1[i]&&!ins2[i]) notstr.push_back(ch);

}

//输出四行

cout<<"in s1 or s2:"<<orstr<<endl;

cout<<"in s1 and s2:"<<andstr<<endl;

cout<<"in s1 but not in s2 ,or in s2 but not in s1:"<<xorstr<<endl;

cout<<"not in s1 and s2:"<<notstr<<endl;

}

return 0;

}

个人思考:

这道题需要将两个字符串的每个字符出现存在对应的布尔数组里,构造四种结果字符串,i从0遍历到25,通过双目运算符来判断四种情况属于哪一种,将对应的结果加入结果字符串中。

T93:隐藏口令------字符串

代码实现:

#include <iostream>

#include <string>

using namespace std;

// 最小表示法,返回最小表示起始位置(0-based)

int minfunction(const string &s, int n) {

int i = 0, j = 1, k = 0;

while (i < n && j < n && k < n) {

int a = s[(i + k) % n];

int b = s[(j + k) % n];

if (a == b) {

++k;

} else {

if (a > b) i = i + k + 1;

else j = j + k + 1;

if (i == j) ++j;

k = 0;

}

}

return min(i, j);

}

int main() {

int L;

cin >> L;// 读取长度

string s, line;

while (cin >> line) {// 逐词读入,自动跳过换行和空格

s += line;

if (s.size() >= L) break;

}

s = s.substr(0, L);//只取前 L 个字符

int pos = minfunction(s, L);

cout << pos << endl;//起始位置减 1 即为口令

return 0;

}

个人思考:

这道题的关键就是最小起始位置的寻找,用三个指针来标记,两个是比较的位置,还有一个是用来表示从这两个位置开始已经成功匹配的字符数。如果相等则继续向后比较,谁大则需要跳到i+k+1或者j+k+1的位置,如果i和j相等,则开始新一轮的比较。

T94:求字符串的起始位置------字符串

代码实现:

#include <iostream>

#include <string>

using namespace std;

int main(){

string s,subs;

while(cin>>s>>subs){

int slen=s.length();

int subslen =subs.length();

int pos=0;//0 表示未找到

//如果子串长度大于主串

if(subslen<=slen){

//遍历可能的起始位置

for(int i=0;i<=slen-subslen;i++){

bool match=true;

for(int j=0;j<subslen;j++){

if(s[i+j]!=subs[j]){

match=false;

break;

}

}

if(match){

pos=i+1;//位置从1开始

break;

}

}

}

cout<<pos<<endl;

}

return 0;

}

个人思考:

这道题首先要记录下主串和子串的长度,然后暴力匹配,外层循环遍历主串:从0到主串和子串的长度之差,内层循环比较s[i+j]与subs[j]是否相同,如果都匹配则返回i+1,如果不匹配就跳出,默认没找到就是0。

英语翻译:

P66:III.理论与实践

计算机科学是理论、工程与实验的结合体。在某些情况下,计算机科学家先提出理论,然后基于该理论设计出一套软硬件结合的系统,并通过实验对其进行测试。这种以理论为驱动的方法的一个典型例子是:开发新的软件工程工具,随后在实际应用中对其进行评估。而在另一些情况下,实验也可能催生新的理论,例如:人们发现人工神经网络表现出与大脑中神经元类似的行为,这一发现进而推动了神经生理学领域新理论的诞生。

neurons:神经元(也叫神经细胞)

neurophysiology:神经生理学

P67:计算机的可预测性似乎会让实验变得没有必要,因为实验的结果理应可以提前预知。但当计算机系统及其与现实世界的交互变得足够复杂时,就可能产生不可预见的行为。因此,实验和传统的科学方法是计算机科学的关键组成部分。

nature:性质、特性

interactions:交互、相互作用

unforeseen:不可预见的、意料之外的

P68:IV.计算机科学的主要分支

计算机科学可划分为四个主要领域:软件开发、计算机体系结构(硬件)、人机交互(设计最高效的人机使用方式)以及人工智能(尝试让计算机表现出智能行为)。软件开发关注创建能高效运行的计算机程序。人工智能(AI)与人机交互领域通常需要同时开发软件和硬件,以解决特定问题。

architecture:计算机体系结构

interface:名词:接口 / 界面;动词:交互 / 对接

背单词:

相关推荐
xsyaaaan3 小时前
leetcode-hot100-双指针:283移动零-11盛最多水的容器-15三数之和-42接雨水
算法·leetcode
一方热衷.5 小时前
YOLO26-Seg ONNXruntime C++/python推理
开发语言·c++·python
炽烈小老头7 小时前
【每天学习一点算法 2026/03/08】相交链表
学习·算法·链表
一碗白开水一7 小时前
【工具相关】OpenClaw 配置使用飞书:打造智能飞书助手全流程指南(亲测有效,放心享用)
人工智能·深度学习·算法·飞书
仰泳的熊猫7 小时前
题目2194:蓝桥杯2018年第九届真题-递增三元组
数据结构·c++·算法
Tisfy8 小时前
LeetCode 1888.使二进制字符串字符交替的最少反转次数:前缀和O(1)
算法·leetcode·字符串·题解
2301_803554528 小时前
linux 以及 c++编程里对于进程,线程的操作
linux·运维·c++
滴滴答滴答答8 小时前
机考刷题之 9 LeetCode 503 下一个更大元素 II
算法·leetcode·职场和发展
飞Link9 小时前
梯度下降的优化算法中,动量算法和指数加权平均的区别对比
人工智能·深度学习·算法