PAT-乙级 1009 说反话(C语言)

#include <stdio.h> 
#include <string.h>
#include <stdlib.h>
int main() {
	char charArray[100] = "";	//定义相应的数组并且初始化
	gets(charArray);	//获取字符串
	if (strchr(charArray, ' ') == NULL) {
		printf(charArray);
	}
	else {
		while (strchr(charArray, ' ' )!= NULL) {
			printf("%s ", strrchr(charArray, ' ') + 1);//加1操作是使指针后移一位(因为char字符的长度为1)
			//注意%s后面有个空格
			*strrchr(charArray, ' ') = 0;
		}
		printf("%s", charArray);
	}
	//system("pause");
	return 0;
}

这是CSDN上一位大佬写的代码,很遗憾,在我准备写篇博客的时候,已经找不到他的博客地址了

通过他的解法,我新学了两个函数 strchr 以及 strrchr

另外,printf(str) 居然还能这样输出,但好像只能输入字符数组,详情还有待考究

最后还是贴上我自己的代码,改了半天测试点4还是通不过,难搞哦~

#include<stdio.h>
#include<string.h>
/*
大概思路:判断有几个单词,每个单词有几个字母,分别将数据放在数组中
		读取的时候按顺序读取
*/

int main() {
	int i, j, k;
	char charArray[82] = { '\0' };		//接受输入的字符串
	for (i = 0; i < 82; i++) {
		scanf("%c", &charArray[i]);
		if (charArray[i] == '\n') {
			break;
		}
	}
	int initialPositionRecord[80] = { 0 };		//首字母位置记录
	int letterNumberRecord[80] = { 0 };			//每个单词多少个字母

	int charNumber = 0;							//字符数
	int wordsNumber=0;							//单词数
	for (i = 0;; i++) /*记录一共多少个字符*/{
		if (charArray[i] == '\n') /*回车的ASC码值是13*/{
			break;
		}
		charNumber++;
	}
	//判断多少个单词以及每个单词的首字母所在的位置
	for (i = 0; i < charNumber; i++) {
		if (charArray[i] >= 65 && charArray[i] <= 90 )/*位置是大写字母*/ {
			if(i==0/*该大写字母是最开始哪一个*/||
				(charArray[i-1]==' '&& charArray[i+1]==' ') ||
				(charArray[i-1]==' ' && charArray[i+1]>=97 && charArray[i+1]<=122)
				){
				initialPositionRecord[wordsNumber] = i;
				for (j = i;; j++) {
					if (charArray[j] == 32 || charArray[j]=='\n' || charArray[j]=='\0') {
						letterNumberRecord[wordsNumber] = j - i;
						break;
					}
				}
				wordsNumber++;
			}
		}
	}
	//输出
	for (i = wordsNumber-1; i>=0; i--) {
		for (k = initialPositionRecord[i];;k++) {
			if (charArray[k] == ' ' || charArray[k]=='\n') {
				break;
			}
			printf("%c", charArray[k]);
		}
		if (i != 0) {
			printf(" ");
		}
	}
	//printf("\n字符数:%d\n", charNumber);
	//printf("单词数:%d\n",wordsNumber);
	
	//system("pause");
	return 0;
}
发布了21 篇原创文章 · 获赞 2 · 访问量 1599

猜你喜欢

转载自blog.csdn.net/tothk/article/details/104203183