3716. 命名法 北京师范大学考研机试题 模拟思想

驼峰式命名法 :当变量名或函数名是由一个或多个单词连结在一起,而构成的唯一识别字时,第一个单词以小写字母开始;从第二个单词开始以后的每个单词的首字母都采用大写字母,例如:myFirstNamemyLastName,这样的变量名看上去就像骆驼峰一样此起彼伏,故得名。

下划线命名法 :名称中的每一个逻辑点都用一个下划线来标记,例如:print_employee。下划线命名法是随着 C 语言的出现流行起来的,在 UNIX/LINUX 这样的环境,以及 GUN 代码中使用非常普遍。

现在给定你一个驼峰式命名法命名的变量名,请你将其转化为下划线命名法命名后输出。

输入格式

输入包含多组测试数据。

每组数据占一行,包含一个驼峰式命名法命名的变量名。

输出格式

每组数据输出一行结果,表示对应的下划线命名法命名。

数据范围

输入最多包含 100100 组数据。

每个输入字符串的长度不超过 100100 且只包含大小写字母。

输入样例:
复制代码
myFirstName
myLastName
输出样例:
复制代码
my_first_name
my_last_name
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

string s;
int ans[1000];
int k=0;
int main()
{
    while(cin>>s){
        k=0;
        //cout<<s;
        int len =s.length();
        //cout<<len<<"\n";
        for(int i = 0;i<len;i++){
            if(s[i]>='A'&&s[i]<='Z')
            {
                //cout<<s[i];
                ans[++k]=i;
            }
            
        }
        for(int i = k; i>=1;i--){
            int a=ans[i];
           // cout<<s[a];
            s[a]=s[a]+32;
            for(int j=len;j>a;j--)
            {
                s[j]=s[j-1];
            }
            s[a]='_';
            len++;
           
        }
        for(int i = 0; i <len; i++){
            cout<<s[i];
        }
         cout<<"\n";
    }
    return 0;
}
相关推荐
少林码僧19 分钟前
2.30 传统行业预测神器:为什么GBDT系列算法在企业中最受欢迎
开发语言·人工智能·算法·机器学习·ai·数据分析
豆沙沙包?19 分钟前
2026年--Lc343-1926. 迷宫中离入口最近的出口(图 - 广度优先搜索)--java版
java·算法·宽度优先
CoderCodingNo24 分钟前
【GESP】C++六级考试大纲知识点梳理, (7) 栈与队列
开发语言·c++
超级大福宝31 分钟前
【力扣200. 岛屿数量】的一种错误解法(BFS)
数据结构·c++·算法·leetcode·广度优先
独自破碎E31 分钟前
【动态规划=递归+记忆化存储】跳台阶
算法·动态规划
一颗青果1 小时前
auto | 尾置返回类型 | decltype | using | typedef
java·开发语言·算法
郝学胜-神的一滴1 小时前
何友院士《人工智能发展前沿》全景解读:从理论基石到产业变革
人工智能·python·深度学习·算法·机器学习
BHXDML1 小时前
第五章:支持向量机
算法·机器学习·支持向量机
2401_841495641 小时前
具身智能:从理论到现实,人工智能的下一场革命
人工智能·算法·机器人·硬件·具身智能·通用智能·专用智能
Felven1 小时前
B. MEXor Mixup
算法