7-18 对象关系映射(orm_name)---PTA实验C++

一、题目描述

一开始看到对象关系映射,其实我是拒绝的。这三个词凑一块,能是给C++初学者的题吗?

再仔细读需求,才发现在课设项目已经用过这功能。Object Relational Mapping(ORM)就是面向对象(OO)侧的模型类、对象、属性与数据库(DB)的表(关系)、记录(行)、列对应,由ORM框架完成两侧的相互转换。

语言侧标识符区分大小写,使用驼峰表示法。而数据库的标识符不区分大小写,要用下划线分隔单词。例如:

  • 语言中的属性studentId,对应数据库的student_id。就是大写字母要改成小写,并且如果不是首个字母,还要在前面追加一个下划线。
  • 语言侧的类名StudentHonor,对应数据库的表名student_honor,对应。与属性不同,类名首字母要大写。

这种标识符映射在做课设项目特别是Repository类里惹了不少乱子。为了彻底弄清这个知识点,亲自实现标识符映射功能是个好办法。

先导题:标识符。

输入规格
  • 每行一组数据,读取到EOF为止。
  • 每组数据有类型、标识符两个字符串,间隔若干空白符。
    • 类型:class field table column四种之一。
    • 标识符:待转换的字符串。
  • 本题不考察算法的时空复杂度。
输出规格
  • 每行输出一组转换结果。
样例输入
class StudentHonor
field studentId
table course
column pre_course_id
样例输出
table student_honor
column student_id
class Course
field preCourseId
样例解释
  • 第1组:class对应table,字母全改成小写,中间的大写字母前要插入下划线分割。
  • 第2组:field对应column,同上。
  • 第3组:table对应class,首字母大写,去掉下划线,下划线后续字母也大写。
  • 第4组:column对应field,去掉下划线,下划线后续字母改大写。

二、注意事项

str一次只能拼接一个变量值,否则会出现乱码

str+='_';

str+=c;

三、完整C++代码实现

#include<iostream>
using namespace std;
#include<string>
string t_x(string s){string str="";for(int i=0;i<s.size();i++){char c=s[i];if(c>='A'&&c<='Z'){c+=32;if(i!=0){str+='_';str+=c;}else{str+=c;}}else{str+=c;}}return str;
}
string x_t(string type,string s){string str="";for(int i=0;i<s.size();i++){char c=s[i];if(i==0&&type=="table"){c-=32;}if(c=='_'){i++;c=s[i]-32;str+=c;}else{str+=c;}}return str;
}
string x_t_2(string s){}int main(){string type,id;while(cin>>type>>id){if(type=="class"){cout<<"table"<<" "<<t_x(id)<<endl;}else  if(type=="field"){cout<<"column"<<" "<<t_x(id)<<endl;} if(type=="table"){cout<<"class"<<" "<<x_t(type,id)<<endl;} if(type=="column"){cout<<"field"<<" "<<x_t(type,id)<<endl;}}}

四、测评详情

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/21061.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机基础之:LSM树

使用过hbase、cassandra之类nosql数据库的小伙伴对LSM树结构应该有所耳闻&#xff0c;那么这种数据结构有哪些优劣势呢&#xff0c;本文做下简单介绍。 LSM&#xff08;全称&#xff1a;Log-Structured Merge Tree&#xff09;是一种广泛应用于现代数据库和存储系统的数据结构…

《平渊》· 柒 —— 大道至简?真传一句话,假传万卷书!

《平渊》 柒 "真传一句话, 假传万卷书" 对于 "大道至简"&#xff0c;不少专家可能会说出一大堆乱七八糟的名词, 比如这样&#xff1a; 所谓 "大道" 即支撑天地运转的 "系统自动力"&#xff0c;更具体地来说&#xff0c;即是天地人以…

快手游戏《无尽梦回》官宣开测:热血动作肉鸽来袭

易采游戏网最新消息&#xff1a;5月30日11:00&#xff0c;快手自研的梦境主题动作冒险手游《无尽梦回》正式宣布开启测试。此次测试名为“肉鸽进化实验”&#xff0c;旨在测试多角色技能交会的玩法。游戏将开放32人同局竞技&#xff0c;让玩家在激烈的战斗中角逐出唯一的胜利者…

HTML如何让文字底部线条不紧贴在文字下面(既在内容下方又超出内容区域)

hello&#xff0c;大家好&#xff0c;星途星途今天给大家带来的内容是如何让文字底部线条不紧贴在文字下面。 话不多说&#xff0c;先上效果图 简单来说就是padding和margin的区别。 在网页设计中&#xff0c;有时我们想要给某个元素添加一个装饰性的线条&#xff0c;比如底部…

过滤器、监听器、拦截器的区别

过滤器、监听器、拦截器的区别 过滤器&#xff08;filter&#xff09;、监听器&#xff08;Listener&#xff09;是JavaWeb的三大组件。而拦截器&#xff08;Interceptor&#xff09;是Spring框架中的。 我们主要是要分清除过滤器和拦截器的区别&#xff1a; 实现原理&#…

overleaf 写参考文献引用

目录 1、 新建.bib 文件 2、导入引用 3、在文档中引用参考文献 4、生成参考文献列表 1、 新建.bib 文件 在Overleaf项目中&#xff0c;你可以选择导入现有的 .bib 文件或在项目中创建一个新的 .bib 文件来管理你的参考文献。 导入.bib 文件&#xff1a; 在项目文件树中点击…

11. RBAC权限管理从零到一实现(二)

前端页面已提交至git https://github.com/SJshenjian/cloud-web默认用户名密码admin 1

MySql 数据类型选择与优化

选择优化的数据类型 更小的通常更好 一般情况下尽量使用可以正确存储数据的最小类型。更小的数据类型通常更快&#xff0c;因为它们占用更少的磁盘&#xff0c;内存和CPU缓存&#xff0c;并且处理时需要的CPU周期也更少。但也要确保没有低估需要存储值的范围。 简单就好 简单的…

【自然语言处理】【Scaling Law】Observational Scaling Laws:跨不同模型构建Scaling Law

相关博客 【自然语言处理】【Scaling Law】Observational Scaling Laws&#xff1a;跨不同模型构建Scaling Law 【自然语言处理】【Scaling Law】语言模型物理学 第3.3部分&#xff1a;知识容量Scaling Laws 【自然语言处理】Transformer中的一种线性特征 【自然语言处理】【大…

jmeter性能优化之tomcat配置与基础调优

一、 修改tomcat初始和最大堆内存 进入到/usr/local/tomcat7-8083/bin目录下&#xff0c;编辑catalina.sh文件&#xff0c;&#xff0c;默认堆内存是600m&#xff0c;初始堆内存和最大堆内存保持一致&#xff0c; 可以更改到本机内存的70%&#xff0c;对于Linux系统&#xff0…

conda创建虚拟环境并激活

1 conda activate base 2 conda creat -n aaa python** 3 conda activate aaa 4 interpreter里面去选择刚搞好的编译器 ...../conda.exe

【SpringBoot】四种读取 Spring Boot 项目中 jar 包中的 resources 目录下的文件

本文摘要&#xff1a;四种读取 Spring Boot 项目中 jar 包中的 resources 目录下的文件 &#x1f60e; 作者介绍&#xff1a;我是程序员洲洲&#xff0c;一个热爱写作的非著名程序员。CSDN全栈优质领域创作者、华为云博客社区云享专家、阿里云博客社区专家博主。公粽号&#xf…

【操作系统】Windows平台捕获崩溃现场底层原理,附代码亲测MiniDumpWriteDump

MiniDumpWriteDump 是一个Windows API函数&#xff0c;它属于DbgHelp.dll库&#xff0c;用于生成程序崩溃时的内存转储文件&#xff08;MiniDump&#xff09;。这个函数是Windows平台下用于捕获程序崩溃时的内存状态的常用方法之一。以下是MiniDumpWriteDump函数的原理和工作流…

【C++】ios::sync_with_stdio(false) 与 cin.tie(nullptr) 加速 IO

一、前言 之前写题遇到大数据量&#xff08;cin、cout 数据量级达到 1e5、1e6 &#xff09;&#xff0c;因为考虑 IO 性能报错 TLE&#xff0c;故选择 scanf、printf 替代 cin、cout&#xff0c;以解决问题。一直以来没有深入研究其中原因&#xff0c;只知关键词——同步&…

设计模式(十三)行为型模式---命令模式

文章目录 命令模式简介结构UML图具体实现UML图代码实现 命令模式简介 命令模式&#xff08;command pattern&#xff09;也叫动作模式或者事务模式。它是将请求&#xff08;命令&#xff09;封装成对象&#xff0c;使得可以用不同的请求对客户端进行参数化&#xff0c;具体的请…

MD中 面料的物理属性参数

该图片是Marvelous Designer软件中"Fabric Physical Properties"(面料物理属性)面板的截图,用于调整面料在弯曲、折叠时的硬度(Buckling Stiffness)。 目标部分解释了调整Buckling Stiffness的作用:通过调整该百分比值来决定面料角落处的硬度。进入80%的Buckling St…

笔记-anaconda配置Python环境

查看环境 conda env list 创建python name环境,python版本为3.9&#xff1a; conda create -n name python3.9 激活&#xff1a; conda activate name 去掉激活&#xff1a; conda deactivate name 进入pandas目录&#xff1a; cd D:\学习\pyton\antpy代码\ant-learn-…

NXP RT1060学习总结 - CANFD功能

1、RT1060-CAN FD功能简介 这里使用RT1060系列的1064芯片进行开发&#xff0c;测试板是官方提供的开发板&#xff1b;RT1060系列支持3路CAN功能&#xff0c;CAN1和CAN2只能最为普通的CAN外设&#xff0c;支持CAN2.0&#xff0c;而CAN3支持CAN-FD功能&#xff1b;CAN-FD功能这里…

【LeetCode 77. 组合】

1. 题目 2. 分析 本题有个难点在于如何保存深搜得到的结果&#xff1f;总结了一下&#xff0c;深搜处理的代码&#xff0c;关于返回值有三大类。 第一类&#xff1a;层层传递&#xff0c;将最深层的结果传上来&#xff1b;这类题有&#xff1a;【反转链表】 第二类&#xff1…

域名/子域名接管漏洞

域名/子域名接管漏洞 1.域接管2.子域接管子域接管概述使用BBOT扫描可劫持的子域通过DNS通配符生成子域接管 3.利用子域接管4.子域名接管防御手段 1.域接管 如果您发现某个域名被某个服务使用&#xff0c;但公司已经失去了对其的所有权&#xff0c;您可以尝试注册它&#xff08…