在C语言中,字符串是一系列字符的集合,每个字符都对应一个ASCII码。我们可以利用位运算来操作和处理字符串。以下是一些常见的位运算技巧:
#include<stdio.h>
void to_uppercase(char *str) {
for (int i = 0; str[i]; i++) {
if (str[i] >= 'a' && str[i] <= 'z') {
str[i] |= 32;
}
}
}
void to_lowercase(char *str) {
for (int i = 0; str[i]; i++) {
if (str[i] >= 'A' && str[i] <= 'Z') {
str[i] &= ~32;
}
}
}
int main() {
char str[] = "Hello, World!";
printf("Original: %s\n", str);
to_uppercase(str);
printf("Uppercase: %s\n", str);
to_lowercase(str);
printf("Lowercase: %s\n", str);
return 0;
}
#include<stdio.h>
#include<string.h>
void reverse(char *str) {
int len = strlen(str);
for (int i = 0, j = len - 1; i < j; i++, j--) {
char temp = str[i];
str[i] = str[j];
str[j] = temp;
}
}
int main() {
char str[] = "Hello, World!";
printf("Original: %s\n", str);
reverse(str);
printf("Reversed: %s\n", str);
return 0;
}
#include<stdio.h>
#include<string.h>
int is_palindrome(const char *str) {
int len = strlen(str);
for (int i = 0, j = len - 1; i < j; i++, j--) {
if (str[i] != str[j]) {
return 0;
}
}
return 1;
}
int main() {
const char *str1 = "level";
const char *str2 = "hello";
printf("%s is palindrome: %s\n", str1, is_palindrome(str1) ? "Yes" : "No");
printf("%s is palindrome: %s\n", str2, is_palindrome(str2) ? "Yes" : "No");
return 0;
}
这些位运算技巧可以帮助你更高效地处理字符串。当然,还有其他许多技巧和方法可以用于字符串操作,这里只是列举了一些常见的例子。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。