B-1014/A-1061 福尔摩斯的约会 (20分)

本篇介绍了一个有趣的编程挑战,通过解析特殊编码的字符串来确定约会的具体时间。文章提供了一段C++代码实现,该算法能够从输入的字符串中找出隐藏的日期和时间信息。

B-1014/A-1061 福尔摩斯的约会 (20分)

大侦探福尔摩斯接到一张奇怪的字条:我们约会吧! 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 <stdio.h>
#include <string>
#include <iostream>
using namespace std;

int main(){
    int i,j,m;
    string str1,str2,str3,str4;
    char day[7][5]={"MON","TUE","WED","THU","FRI","SAT","SUN"};
    cin >> str1;
    cin >> str2;
    cin >> str3;
    cin >> str4;
    for(i=0;i<str1.size()&&i<str2.size();i++){//输出日期
        if(str1[i]==str2[i]&&str1[i]>='A'&&str1[i]<='G'){
            cout << day[str1[i]-'A'] << ' ';
            break;
        }
    }
    for(i++;i<str2.size()&&i<str1.size();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("%02d:",str1[i]-'A'+10);
                break;
            }
        }
    }
    for(i=0;i<str3.size()&&i<str4.size();i++){//寻找分钟数
        if(str3[i]==str4[i]){
            if((str3[i]<='z'&&str3[i]>='a')||(str3[i]<='Z'&&str3[i]>='A')){
                printf("%02d",i);
                break;
            }
        }
    }
    return 0;
}

<think>好的,我现在需要帮助用户找到Hadoop集群中yarn-site.xml文件的位置,特别是在hadoop-2.7.2版本中。首先,我应该回忆一下Hadoop的配置文件通常存放在哪里。根据之前的经验,Hadoop的配置文件通常位于安装目录的etc/hadoop子目录下。比如,如果Hadoop安装在/opt/module/hadoop-2.7.2,那么配置文件路径应该是/opt/module/hadoop-2.7.2/etc/hadoop/。 不过,用户可能的环境可能有所不同,所以需要确认他们的安装路径是否正确。用户提供的引用[1]中提到了core-site.xml的配置,里面有一个路径是/opt/module/hadoop-2.7.2/data/tmp,这说明用户的Hadoop安装目录可能是在/opt/module/hadoop-2.7.2下。因此,yarn-site.xml很可能在/opt/module/hadoop-2.7.2/etc/hadoop/yarn-site.xml。 另外,用户可能在配置过程中遇到了权限问题,如引用[3]中的错误,这可能和配置文件的位置无关,但需要确保用户有权限访问该文件。此外,引用[5]提到启动yarn时的问题,如果yarn-site.xml的位置不正确或者配置有误,也可能导致启动失败,所以确认文件位置很重要。 另外,用户可能需要通过命令行查找文件的位置,比如使用find命令。例如,在Hadoop的安装目录下运行find命令:find /opt/module/hadoop-2.7.2 -name yarn-site.xml,这样可以快速定位文件是否存在。 还需要提醒用户,如果集群是多节点部署,每个节点上的配置文件可能需要保持一致,特别是yarn-site.xml中的资源管理器地址等配置,如引用[4]提到的CapacityScheduler相关的配置可能存在于该文件中。 总结步骤应该是:1. 确定Hadoop安装路径;2. 检查etc/hadoop目录下的yarn-site.xml;3. 使用find命令查找;4. 确认配置正确性和权限。同时,生成相关问题需要考虑用户可能遇到的后续问题,比如配置参数、权限错误处理等。</think>### 定位 Hadoop 环境下 yarn-site.xml 文件路径的方法 在 Hadoop 2.7.2 版本中,`yarn-site.xml` 文件通常位于 Hadoop 安装目录的 `etc/hadoop` 子目录下。具体路径为: $$ /opt/module/hadoop-2.7.2/etc/hadoop/yarn-site.xml $$ 若安装路径不同(例如通过自定义路径安装),可通过以下方法验证: 1. **检查默认安装路径** 根据引用[1]中 `core-site.xml` 的配置示例,Hadoop 运行时目录为 `/opt/module/hadoop-2.7.2`,因此 `yarn-site.xml` 应位于其子目录 `etc/hadoop` 下。 2. **使用命令行查找** 在 Linux 系统中,可通过 `find` 命令全局搜索: ```bash find /opt/module/hadoop-2.7.2 -name "yarn-site.xml" ``` 3. **验证配置文件内容** 若文件存在,打开后可检查 YARN 相关配置参数,例如资源管理地址(如引用[3]中提到的 `hadoop03:8031`)或调度器类型(如引用[4]中的 `CapacityScheduler`)。 --- ### 注意事项 - **权限问题**:若搜索时提示权限不足,需确保当前用户对 Hadoop 安装目录有读取权限(参考引用[3]中提到的权限错误场景)。 - **集群环境**:若 Hadoop 是布式集群部署,需确认所有节点上的 `yarn-site.xml` 文件路径和内容一致(参考引用[5]中伪布式环境配置)。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值