J - 简单枚举类型——植物与颜色
Description
请定义具有red, orange, yellow, green, blue, violet六种颜色的枚举类型color,根据输入的颜色名称,输出以下六种植物花朵的颜色:
Rose(red), Poppies(orange), Sunflower(yellow), Grass(green), Bluebells(blue), Violets(violet)。如果输入的颜色名称不在枚举类型color中,例如输入purple,请输出I don’t know about the color purple.
Input
第一行输入一个n, 代表有n 组询问。( 1 <= n <= 10)
接下来的n行, 每行有一个字符串代表颜色名称,颜色名称最多30个字符。
Output
输出n 行。
每行输出对应颜色的植物名称。
例如:Bluebells are blue. 如果输入的颜色名称不在枚举类型color中,例如purple, 请输出I don’t know about the color purple.
Sample
Input
3
blue
yellow
purple
Output
Bluebells are blue.
Sunflower are yellow.
I don’t know about the color purple.
Hint
请用枚举类型实现。
#include<bits/stdc++.h>
using namespace std;
enum node
{
red, orange, yellow, green, blue, violet,other
} color;
int main()
{
char a[30];
int n;
scanf("%d",&n);
for(int i=0; i<n; i++)
{
scanf("%s",a);
if(strcmp(a,"red")==0)
color=red;
else if(strcmp(a,"orange")==0)
color=orange;
else if(strcmp(a,"yellow")==0)
color=yellow;
else if(strcmp(a,"green")==0)
color=green;
else if(strcmp(a,"blue")==0)
color=blue;
else if(strcmp(a,"violet")==0)
color=violet;
else
color=other;
switch(color)
{
case red:
printf("Rose are red.\n");
break;
case orange:
printf("Poppies are orange.\n");
break;
case yellow:
printf("Sunflower are yellow.\n");
break;
case green:
printf("Grass are green.\n");
break;
case blue:
printf("Bluebells are blue.\n");
break;
case violet:
printf("Violets are violet.\n");
break;
case other:
printf("I don't know about the color %s.\n",a);
break;
}
}
}