#include<stdio.h> int len(char a[]) { int b=0; for(int i=0;a[i]!=0;i++) //a[i]!=0 表示数组中的i不为0 b++; return b; } int main() { printf("请输入字符串:"); char str[100]; gets(str); printf("长度为:%d",len(str)); return 0; }
时间: 2024-01-22 08:03:15 浏览: 27
这段代码看起来已经很简洁了,但是在实际使用中可能会存在一些问题,下面是一些可能的优化建议:
1. 在 `len()` 函数中,变量 `b` 可以直接声明为 `size_t` 类型,因为它表示的是数组长度,这个值不可能为负数。
2. 在 `len()` 函数中,可以使用指针来遍历数组,这样可以避免使用下标访问数组元素时的越界问题。
3. 在 `main()` 函数中,可以使用 `fgets()` 函数来读取用户输入的字符串,这样可以避免使用 `gets()` 函数时可能出现的缓冲区溢出问题。
4. 在 `main()` 函数中,可以使用 `%zu` 格式化符号来输出 `size_t` 类型的值。
下面是优化后的代码示例:
```c
#include <stdio.h>
size_t len(char *a) {
size_t b = 0;
while (*a++) {
b++;
}
return b;
}
int main() {
printf("请输入字符串:");
char str[100];
fgets(str, sizeof(str), stdin);
size_t length = len(str);
printf("长度为:%zu\n", length);
return 0;
}
```
相关问题
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <stdint.h> #define SHA1_BLOCK_SIZE 20 #define SHA1_DIGEST_SIZE 5
SHA-1是一种密码散列函数,用于产生消息的数字指纹。SHA-1算法的输出长度为160位,即20个字节。在C语言中,可以使用以下代码来实现SHA-1算法:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdint.h>
#define SHA1_BLOCK_SIZE 20
#define SHA1_DIGEST_SIZE 5
void sha1(const uint8_t *message, size_t message_len, uint8_t *digest) {
// TODO: 实现SHA-1算法
}
int main() {
uint8_t message[] = "hello world";
uint8_t digest[SHA1_DIGEST_SIZE];
sha1(message, strlen((char *)message), digest);
printf("SHA-1 digest: ");
for (int i = 0; i < SHA1_DIGEST_SIZE; i++) {
printf("%02x", digest[i]);
}
printf("\n");
return 0;
}
```
#include <stdio.h> #include <string.h> void reverse(char *str) { int len = strlen(str); for (int i = 0; i < len/2; i++) { char temp = str[i]; str[i] = str[len - i - 1]; str[len - i - 1] = temp; } } int main() { char str[] = "Hello World!"; printf("Original String: %s\n", str); reverse(str); printf("Reversed String: %s\n", str); return 0; }纠错
这段代码的实现是将一个字符串进行翻转,并输出翻转后的结果。代码中出现了一个小错误,应该在开头添加一个换行符,即将第一行改为:
```
#include <stdio.h>
#include <string.h>
```
同时,建议在输出翻转后的字符串时,也加上一个换行符,以便更好地显示输出结果。修改后的代码如下:
```
#include <stdio.h>
#include <string.h>
void reverse(char *str) {
int len = strlen(str);
for (int i = 0; i < len/2; i++) {
char temp = str[i];
str[i] = str[len - i - 1];
str[len - i - 1] = temp;
}
}
int main() {
char str[] = "Hello World!";
printf("Original String: %s\n", str);
reverse(str);
printf("Reversed String: %s\n\n", str);
return 0;
}
```
相关推荐
![text/x-c](https://img-home.csdnimg.cn/images/20210720083646.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)