算法笔记第三章练习题-字符串02

题目 B1002 写出这个数
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu

#include <cstdio>
#include <cstring>
int main()
{
	char str[110];
	gets(str);
	int len = strlen(str);
	int sum = 0;
	for(int i;i<len;i++)
	{
		sum += str[i] -'0';
	}
	int num = 0,ans[10];
	while (sum != 0)
	{
		ans[num++] = sum %10;
		sum /=10;
		
	}
	char change[10]= {
	'ling','yi','er','san','si','wu','liu','qi','ba','jiu'
	};
	for( int i = num-1;i >=0;i--)
	{
		printf("%s",change[ans[i]]);
		if(i!=0)
		{
			printf(" ");
		}
		else printf("\n");
	}
	return 0;
}

题目:说反话

给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。

输入格式:测试输入包含一个测试用例,在一行内给出总长度不超过80的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用1个空格分开,输入保证句子末尾没有多余的空格。

输出格式:每个测试用例的输出占一行,输出倒序后的句子。

输入样例:

Hello World Here I Come

输出样例:

Come I Here World Hello
 

#include <cstdio>

int main()
{ 
int num = 0;
char ans[90][90];
while(scanf("%s",ans[num])!=EOF)
{
	num++;
 } 
 for(int i = num- 1;i>=0;i--)
 {
 	printf("%s",ans[i]);
 	if (i >0)  printf(" ");
 }
 return 0;
	
}

题目:福尔摩斯的约会

大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfdk d&Hyscvnm”。大侦探很快就明白了,字条上奇怪的乱码实际上就是约会的时间“星期四 14:04”,因为前面两字符串中第1对相同的大写英文字母(大小写有区分)是第4个字母’D’,代表星期四;第2对相同的字符是’E’,那是第5个英文字母,代表一天里的第14个钟头(于是一天的0点到23点由数字0到9、以及大写字母A到N表示);后面两字符串第1对相同的英文字母’s’出现在第4个位置(从0开始计数)上,代表第4分钟。现给定两对字符串,请帮助福尔摩斯解码得到约会的时间。

输入格式:

输入在4行中分别给出4个非空、不包含空格、且长度不超过60的字符串。

输出格式:

在一行中输出约会的时间,格式为“DAY HH:MM”,其中“DAY”是某星期的3字符缩写,即MON表示星期一,TUE表示星期二,WED表示星期三,THU表示星期四,FRI表示星期五,SAT表示星期六,SUN表示星期日。题目输入保证每个测试存在唯一解。

输入样例:

3485djDkxh4hhGE
2984akDfkkkkggEdsb
s&hgsfdk
d&Hyscvnm
输出样例:

THU 14:04

# include <cstdio>
# include <cstring>
int main()
{
	char week[7][5] = {
	"MON","TUE","WED","THU","FRI","SAT","SUN"};
	char str1[70],str2[70],str3[70],str4[70];
	gets(str1);
	gets(str2);
	gets(str3);
	gets(str4);
	int len1 = strlen(str1);
	int len2 = strlen(str2);
	int len3 = strlen(str3);
	int len4 = strlen(str4);
	int i;
	for(i = 0;i<len1&&i<len2;i++)
	{
		if(str1[i] == str2[i]&&str1[i]>='A'&&str1[i]<='G')
		{
			printf("%s",week[str1[i]-'A']);       //输出对应是星期几
			break; 
		}
	}
	for(i++;i<len1&&i<len2;i++)
	{
		if(str1[i]==str2[i])
		{
			if(str1[i]>='0' && str1[i]<='9')
			{
				printf("%02d:",str1[i]-'0');
				break;
			}
			else if(str1[i]>='A' && str1[i]<='N')
			{
				printf("%02:",strl[i]-'A'+10);
				break;
			}
		}
	}
	for(i = 0;i<len3&&i<len4;i++)
	{
		if (str3[i] == str4[i])
		{
			if((str3[i]>='A'&&str4[i]<='Z')||(str3[i]>='a'&&str4[i]<='z'))
			{
				printf("%02d",i);
				break;
			}
		}
	}
	return 0;
 } 


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值