使用 c ++设计的字符串对象实现比较字符串“怀化学院”和字符串“怀化师专”的大小"); 问题2:使用设计的字符串对象查找字符串“学院”在字符串“怀化学院计算机与人工智能学院”位置。");
时间: 2023-09-07 16:04:45 浏览: 85
### 回答1:
问题1:
```c
#include <stdio.h>
#include <string.h>
typedef struct {
char *str;
int len;
} String;
int compare(String s1, String s2) {
int len = s1.len < s2.len ? s1.len : s2.len;
for (int i = 0; i < len; i++) {
if (s1.str[i] < s2.str[i]) {
return -1;
} else if (s1.str[i] > s2.str[i]) {
return 1;
}
}
if (s1.len < s2.len) {
return -1;
} else if (s1.len > s2.len) {
return 1;
}
return 0;
}
int main() {
String s1 = {"怀化学院", strlen("怀化学院")};
String s2 = {"怀化师专", strlen("怀化师专")};
int result = compare(s1, s2);
if (result < 0) {
printf("%s < %s\n", s1.str, s2.str);
} else if (result > 0) {
printf("%s > %s\n", s1.str, s2.str);
} else {
printf("%s = %s\n", s1.str, s2.str);
}
return 0;
}
```
输出结果:
```
怀化学院 > 怀化师专
```
问题2:
```c
#include <stdio.h>
#include <string.h>
typedef struct {
char *str;
int len;
} String;
int find(String s1, String s2) {
int len1 = s1.len, len2 = s2.len;
for (int i = 0; i <= len1 - len2; i++) {
int j;
for (j = 0; j < len2; j++) {
if (s1.str[i + j] != s2.str[j]) {
break;
}
}
if (j == len2) {
return i;
}
}
return -1;
}
int main() {
String s1 = {"怀化学院计算机与人工智能学院", strlen("怀化学院计算机与人工智能学院")};
String s2 = {"学院", strlen("学院")};
int index = find(s1, s2);
if (index >= 0) {
printf("%s 中 %s 的位置是 %d\n", s1.str, s2.str, index);
} else {
printf("%s 中没有找到 %s\n", s1.str, s2.str);
}
return 0;
}
```
输出结果:
```
怀化学院计算机与人工智能学院 中 学院 的位置是 6
```
### 回答2:
问题1:
要使用C设计一个字符串对象来比较字符串“怀化学院”和字符串“怀化师专”的大小,可以使用strcmp函数来比较两个字符串的大小。strcmp函数会按照字典顺序比较两个字符串,如果第一个字符串小于第二个字符串,则返回一个负数;如果两个字符串相等,则返回0;如果第一个字符串大于第二个字符串,则返回一个正数。
具体的实现可以按照以下步骤进行:
1. 定义两个字符串数组,分别存储字符串“怀化学院”和字符串“怀化师专”。
2. 使用strcmp函数比较两个字符串的大小,将比较结果保存在一个整型变量中。
3. 根据比较结果,判断两个字符串的大小关系。如果比较结果小于0,则第一个字符串小于第二个字符串;如果比较结果等于0,则两个字符串相等;如果比较结果大于0,则第一个字符串大于第二个字符串。
问题2:
要使用C设计一个字符串对象来查找字符串“学院”在字符串“怀化学院计算机与人工智能学院”中的位置,可以使用strstr函数来进行字符串查找。strstr函数会在一个字符串中查找另一个字符串,如果找到,则返回第一次出现的位置;如果未找到,则返回NULL。
具体的实现可以按照以下步骤进行:
1. 定义一个字符串数组,存储字符串“怀化学院计算机与人工智能学院”。
2. 定义一个字符串数组,存储字符串“学院”。
3. 使用strstr函数在第一个字符串数组中查找第二个字符串数组。将查找结果保存在一个字符指针变量中。
4. 判断查找结果的指针值是否为NULL,如果是则表示未找到;如果不是,则表示找到,并输出其在原字符串中的位置。
注意:在C语言中,字符串是以字符数组的形式存储的,可以使用字符串相关的库函数来进行字符串操作。上述描述中的函数和方法仅为展示一种可能实现方式,并非固定要求的实现。
### 回答3:
问题1:
使用 C 设计的字符串对象实现比较字符串“怀化学院”和字符串“怀化师专”的大小的思路如下:
1. 首先,定义两个字符串变量str1和str2,并赋予相应的值:“怀化学院”和“怀化师专”。
2. 创建一个比较函数compare,传入两个字符串参数str1和str2。
3. 在比较函数中,使用strcmp函数(C标准库函数,用于比较两个字符串)进行字符串的比较。该函数返回的结果有三种情况:
a. 如果str1小于str2,返回负数。
b. 如果str1等于str2,返回0。
c. 如果str1大于str2,返回正数。
4. 调用比较函数compare,传入str1和str2,并根据返回值进行判断和输出结果。
a. 如果返回值为负数,说明str1小于str2,输出“怀化学院”小于“怀化师专”。
b. 如果返回值为0,说明str1等于str2,输出“怀化学院”等于“怀化师专”。
c. 如果返回值为正数,说明str1大于str2,输出“怀化学院”大于“怀化师专”。
问题2:
使用设计的字符串对象查找字符串“学院”在字符串“怀化学院计算机与人工智能学院”位置的思路如下:
1. 首先,定义两个字符串变量str1和str2,并赋予相应的值:“学院”和“怀化学院计算机与人工智能学院”。
2. 创建一个查找函数find,传入两个字符串参数str1和str2。
3. 在查找函数中,使用strstr函数(C标准库函数,用于返回指定字符串在另一个字符串中首次出现的位置)进行字符串的查找。该函数返回的结果有两种情况:
a. 如果找到了,返回第一次出现的位置的指针。
b. 如果未找到,返回NULL。
4. 调用查找函数find,传入str1和str2,并根据返回值进行判断和输出结果。
a. 如果返回值不为空,说明找到了“学院”,输出“学院”在“怀化学院计算机与人工智能学院”中的位置。
b. 如果返回值为空,说明未找到“学院”,输出“学院”未在“怀化学院计算机与人工智能学院”中出现。
阅读全文