memset(str,0,sizeof(char)*100);
时间: 2023-11-26 22:02:31 浏览: 145
这行代码的作用是将字符数组 str 的前 100 个元素全部清零,即赋值为 0。第一个参数是要清零的数组的指针,第二个参数是要清零的值(这里是 0),第三个参数是要清零的字节数,即数组长度。注意第三个参数应该是 sizeof(char)*100,而不是直接写成 100。因为 sizeof(char) 的结果通常是 1,所以两种写法的结果是一样的。这行代码常用于初始化字符数组。
相关问题
#include <stdio.h> #include <string.h> #include <stdlib.h> char* reverse(char* s) { int i = strlen(s); int j = i; char* ptr = (char*)malloc(strlen(s) * sizeof(char)); memset(ptr, 0, strlen(s) * sizeof(char)); i--; for (; i >= 0; i--) { ptr[i] = *s; s++; } ptr[j] = '\0'; s = ptr; return s; } void* obfuscate(void* ptr) { int* p = (int*)ptr; *p = (*p ^ 0xdeadbeef) + 0x1337; return ptr; } int main() { char* str = (char*)malloc(200 * sizeof(char)); printf("Enter a string: "); scanf("%s", str); str = (char*)obfuscate((void*)reverse(obfuscate((void*)str)))); printf("Reversed string: %s\n", str); free(str); return 0; } 整理这个代码格式,使其美观容易阅读
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
char* reverse(char* s) {
int i = strlen(s);
int j = i;
char* ptr = (char*) malloc(strlen(s) * sizeof(char));
memset(ptr, 0, strlen(s) * sizeof(char));
i--;
for (; i >= 0; i--) {
ptr[i] = *s;
s++;
}
ptr[j] = '\0';
s = ptr;
return s;
}
void* obfuscate(void* ptr) {
int* p = (int*) ptr;
*p = (*p ^ 0xdeadbeef) + 0x1337;
return ptr;
}
int main() {
char* str = (char*) malloc(200 * sizeof(char));
printf("Enter a string: ");
scanf("%s", str);
str = (char*) obfuscate((void*) reverse(obfuscate((void*) str)));
printf("Reversed string: %s\n", str);
free(str);
return 0;
}
#include<stdio.h> #include<string.h> #include<stdlib.h> char* reverse(char *s) { int i=strlen(s); int j= i; char *ptr=(char*)malloc(strlen(s)*sizeof(char)); memset(ptr, 0, strlen(s)*sizeof(char)); i--; for(;i>=0 ;i-- ){ ptr[i] = *s; s++; } ptr[j] = '\0'; s=ptr; return s; } int main(){ char *str=(char*)malloc( 200*sizeof(char) ); scanf("%s", str); str = reverse(str); printf("%s", str); return 0; } 优化这代码使其代码量短小性能更好
可以直接在原字符串上进行反转,避免使用额外的空间。同时可以使用两个指针,一个指向字符串的开头,一个指向结尾,交换它们所指向的字符即可。
优化后的代码如下:
```c
#include <stdio.h>
#include <string.h>
char* reverse(char* s) {
int len = strlen(s);
for (int i = 0, j = len - 1; i < j; i++, j--) {
char tmp = s[i];
s[i] = s[j];
s[j] = tmp;
}
return s;
}
int main() {
char str[200];
scanf("%s", str);
printf("%s", reverse(str));
return 0;
}
```
这样代码量更小,性能也更好。
阅读全文