【笔试常见编程题02】字符串中找出连续最长的数字串、数组中出现次数超过一半的数字、计算糖果、进制转换

本文主要是介绍【笔试常见编程题02】字符串中找出连续最长的数字串、数组中出现次数超过一半的数字、计算糖果、进制转换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

1. 字符串中找出连续最长的数字串

读入一个字符串str,输出字符串str中的连续最长的数字串
输入描述
个测试输入包含1个测试用例,一个字符串str,长度不超过255。
输出描述
在一行内输出str中里连续最长的数字串。
示例 1
输入
abcd12345ed125ss123456789
输出
123456789

思路1:

  1. 定义两个string,longfig和temp
  2. temp获取数字字符串,longfig保留最长数字字符串
    如果temp比longfig长,把temp赋值给longfig,temp置空
int main() {string s, longfig, temp; // longfig用来保存最长数字字符串getline(cin, s); for (int i = 0; i < s.size(); i++) // 遍历输入的字符串{while (s[i] - '0' >= 0 && s[i] - '0' <= 9) // 如果为数字,保存到temp{temp += s[i];i++;}if (temp.size() > longfig.size()) // 如果temp比longfig长,则把temp赋值给longfiglongfig = temp;temp = "";}cout << longfig;return 0;
}

2. 数组中出现次数超过一半的数字

给一个长度为 n 的数组,数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。
例如输入一个长度为9的数组[1,2,3,2,2,2,5,4,2]。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。
数据范围:,数组中元素的值
要求:空间复杂度:,时间复杂度
示例 1
输入
[1,2,3,2,2,2,5,4,2]
输出
2
示例 2
输入
[3,3,3,3,2,2,2]
输出
3
示例 3
输入
[1]
输出
1

思路1:

  1. 排序数组
    数字出现次数超过数组长度的一半
    中间那个数一定是最长数组
class Solution {
public:int MoreThanHalfNum_Solution(vector<int>& numbers) {sort(numbers.begin(), numbers.end());return numbers[numbers.size() / 2];}
};

思路2:

  1. 遍历一遍数组
  2. 在map中存每个元素出现的次数
    然后再遍历一次数组,找出众数
class Solution {
public:int MoreThanHalfNum_Solution(vector<int> numbers) {unordered_map<int,int> mp;for (const int val : numbers) ++mp[val];for (const int val : numbers) {if (mp[val] > numbers.size() / 2 ) return val;}return 0;}
};

思路3:(最优解)时间和空间复杂度:O(n),O(1)
如果两个数不相等,就消去这两个数,最坏情况下,每次消去一个众数和一个非众数,那么如果存在众数,最后留下的数肯定是众数

  1. 初始化:候选人cond = -1, 候选人的投票次数cnt = 0
  2. 遍历数组,如果cnt=0, 表示没有候选人,则选取当前数为候选人,++cnt
  3. 否则,如果cnt > 0, 表示有候选人,如果当前数=cond,则++cnt,否则–cnt
  4. 直到数组遍历完毕,最后检查cond是否为众数
class Solution {
public:int MoreThanHalfNum_Solution(vector<int> numbers) {int cond = -1;int cnt = 0;for (int i=0; i<numbers.size(); ++i) {if (cnt == 0) {cond = numbers[i];++cnt;}else {if (cond == numbers[i]) ++cnt;else --cnt;}}cnt = 0;for (const int k :numbers) {if (cond == k) ++cnt;}if (cnt > numbers.size() / 2) return cond;return 0;}
};

3. 计算糖果

A,B,C三个人是好朋友,每个人手里都有一些糖果,我们不知道他们每个人手上具体有多少个糖果,但是我们知道以下的信息:
A - B, B - C, A + B, B + C. 这四个数值.每个字母代表每个人所拥有的糖果数.
现在需要通过这四个数值计算出每个人手里有多少个糖果,即A,B,C。这里保证最多只有一组整数A,B,C满足所有题设条件。
输入描述
输入为一行,一共4个整数,分别为A - B,B - C,A + B,B + C,用空格隔开。 范围均在-30到30之间(闭区间)。
输出描述
输出为一行,如果存在满足的整数A,B,C则按顺序输出A,B,C,用空格隔开,行末无空格。 如果不存在这样的整数A,B,C,则输出No
示例 1
输入
1 -2 3 4
输出
2 1 3

思路1:

  1. (整数1 + 整数3) / 2 = A
  2. (整数2 + 整数4) / 2 = B
  3. B - 整数2 = C
int main() {vector<int> v;int a, b, c;v.resize(4);for (int i = 0; i < 4; i++)cin >> v[i];a = (v[0] + v[2]) / 2;b = (v[1] + v[3]) / 2;c = b - v[1];if (a-b == v[0] && b-c == v[1] && a+b == v[2] && b+c == v[3])cout << a << " " << b << " " << c;else cout << "No";return 0;
}

4. 进制转换

给定一个十进制数M,以及需要转换的进制数N。将十进制数M转化为N进制数
输入描述
输入为一行,M(32位整数)、N(2 ≤ N ≤ 16),以空格隔开。
输出描述
为每个测试实例输出转换后的数,每个输出占一行。如果N大于9,则对应的数字规则参考16进制(比如,10用A表示,等等)
示例 1
输入
7 2
输出
111

思路1:

  1. 十进制转任何其他进制都可以用
    十进制数取模需要转换的进制(转二进制就取模二)
    取模的结果记录下来
  2. 十进制数除以需要转换的进制,所得的结果继续取模
  3. 直到十进制数为0,逆置所有取模的结果就是需要转换的进制

本题需要注意的是十进制数可能为0
和负数的情况,需要特殊处理

void TenScaleConvertOther(int M, int N, string& s) // 十进制转其他进制函数
{char figure[] = { '0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F' };while (M) {s.push_back(figure[M % N]);M = M / N;}
}int main() {int M, N;cin >> M >> N;string s;if (M == 0) // 需要考虑M为0的情况s.push_back('0');TenScaleConvertOther(abs(M), N, s); // M可能为负数, 传绝对值过去reverse(s.begin(), s.end());if (M < 0)cout << '-' << s;else cout << s;   return 0;
}

这篇关于【笔试常见编程题02】字符串中找出连续最长的数字串、数组中出现次数超过一半的数字、计算糖果、进制转换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/654425

相关文章

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

JavaScript对象转数组的三种方法实现

《JavaScript对象转数组的三种方法实现》本文介绍了在JavaScript中将对象转换为数组的三种实用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录方法1:使用Object.keys()和Array.map()方法2:使用Object.entr

Python 常用数据类型详解之字符串、列表、字典操作方法

《Python常用数据类型详解之字符串、列表、字典操作方法》在Python中,字符串、列表和字典是最常用的数据类型,它们在数据处理、程序设计和算法实现中扮演着重要角色,接下来通过本文给大家介绍这三种... 目录一、字符串(String)(一)创建字符串(二)字符串操作1. 字符串连接2. 字符串重复3. 字

Java轻松实现PDF转换为PDF/A的示例代码

《Java轻松实现PDF转换为PDF/A的示例代码》本文将深入探讨Java环境下,如何利用专业工具将PDF转换为PDF/A格式,为数字文档的永续保存提供可靠方案,文中的示例代码讲解详细,感兴趣的小伙伴... 目录为什么需要将PDF转换为PDF/A使用Spire.PDF for Java进行转换前的准备通过

Java 字符串操作之contains 和 substring 方法最佳实践与常见问题

《Java字符串操作之contains和substring方法最佳实践与常见问题》本文给大家详细介绍Java字符串操作之contains和substring方法最佳实践与常见问题,本文结合实例... 目录一、contains 方法详解1. 方法定义与语法2. 底层实现原理3. 使用示例4. 注意事项二、su

Redis高性能Key-Value存储与缓存利器常见解决方案

《Redis高性能Key-Value存储与缓存利器常见解决方案》Redis是高性能内存Key-Value存储系统,支持丰富数据类型与持久化方案(RDB/AOF),本文给大家介绍Redis高性能Key-... 目录Redis:高性能Key-Value存储与缓存利器什么是Redis?为什么选择Redis?Red

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H