当前位置: 代码迷 >> 综合 >> ZCMU--1736: 反射(C语言)
  详细解决方案

ZCMU--1736: 反射(C语言)

热度:97   发布时间:2023-12-06 10:07:19.0

Description
我们都知道人眼对自然界中的景物有不同的彩色感觉是因为日光(光源)包含有各种波长的可见光,
同时景物又具有不同的反射(或透射)特性的缘故。例如:西红柿具有反射红色光谱成分的特性,
在太阳光照射下其中的红色成分(吸收了其他光谱成分),所以人眼看到的西红柿是红色的。如果
把西红柿放到蓝光下,照射到西红柿上的蓝光被它吸收了,人眼看到的将是黑色的西红柿。

Input

我们在每组测试数据的第一行有一个字符,表示某个景物能够反射的颜色,第二行输入的是一行
字符串(长度不超过1000),表示一组照射到该景物上的光源(长度不超过26)。问,是否有光源
照射到景物上能够显示出景物的颜色,如果有则将每个光源按行输出,没有则输出“No!”。
有多组测试数据,每组测试数据的输出结果用一行空行分割开来。

Output

Sample Input

r

ogr   bg   abc   r

e

oga   bw

Sample Output

ogr

r

(有个换行)

No!

解析:我们找到对应字符时候,可以利用单词前后的单词来确定前后端,然后for来逐个输出即可,但第一个和最后一个单词前后最多只有一个空格,所以我们特殊照顾一下,格式注意每次输出完多加个换行。

#include <stdio.h>
#include <string.h>
char a[1005];
int main()
{char k;int i,s,biaoji1,biaoji2,shi,len;while(~scanf("%c",&k)){		//输入能反射的光 getchar();		//吃掉空格 gets(a);		shi=0;		//用来标记有无光源输出 len=strlen(a);for(i=0;i<len;i++){if(a[i]==k){		//如果找到	for(s=i;s>=0;s--){		//确定单词前前端位置 if(a[s]==' '||s==0){  //注意可能第一个就是,所以我们添加个对应条件 biaoji1=s;break;}}for(s=i;s<len;s++){if(a[s]==' '||s==len-1){ //可能是最后一个是,如上 biaoji2=s;break;}}for(s=biaoji1;s<=biaoji2;s++){if(a[s]!=' ') printf("%c",a[s]);//我们确定的前后端位置可能包含空格		}								//所以我们方便一点,直接不是空格输出就可以	shi=1;printf("\n");}}if(shi==0) printf("No!\n");printf("\n");		//注意格式噢 }return 0;
}