两道题目:
1 - >题目内容:写一个函数可以倒序字符的内容
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
//写一个函数,可以逆序一个字符的内容
#include<assert.h>
#include<string.h>
void reverse(char *str)
{
assert(str !=NULL );//str必须是有效的指针
int len = strlen(str);
char* left=str;
char* right = str + len - 1;
while (left < right)
{
char tmp = *left;
*left = *right;
*right = tmp;
left++;
right--;
}
}
int main()
{
char arr[] = "abcdef";//fedcba - 数组内容发生了变化
reverse(arr);
printf("%s\n", arr);
return 0;
}
2.题目描述:将一句话的单词进行倒置,标点不倒置,比如I like beijing.经过函数后变为:beijing.like I
输入描述:每个测试输入包含1个测试用例:I like beijing.输出用例长度不超过100
输出描述:依次输出倒置之后的字符串,以空格分割
实例1:输入:I like beijing.
输出:beijing.like I
//倒置字符串
reverse(char* left, char* right)
{
while (left<right)
{
char tmp = 0;
tmp = *left;
*left = *right;
*right = tmp;
left++;
right--;
}
}
int main()
{
char arr[100] = { 0 };
//不能用scanf()来输入字符串因为中间有空格 就会停止
//输入进来了
gets(arr);
//三步翻转法
//1.字符串整体翻转
//.gnijied.ekil i
int len = strlen(arr);
reverse(arr,arr+len-1);
printf("%s\n", arr);
//2.,每个单词逆序
//beijing.like i
char* start = arr;
while (*start)
{
char* end = start;
while (*end != ' '&&*end!='\0')
{
end++;
}
//逆序一个单词
reverse(start, end - 1);
if (*end == ' ')
start = end + 1;
else
start = end;
}
printf("%s\n",arr);
return 0;
}
补充gets()函数:
字符串输入函数gets格式如下:
gets(字符数组名)
功能:从终端(键盘等)输入一个字符串。本函数的带一个函数值,即为该字符数组的首元素地址
#include<stdio.h>
int main()
{
int a[20];
gets(a);
printf("%s",a);
return 0;
}