[字符串操作] 分割乘积

分割乘积

题目描述

给定一个整数,求插入两个乘号将该整数分割成三个数之后,三个数的的最大乘积。

关于输入

只有一行,一个整数。

关于输出

所求出的最大乘积。

例子输入

	4242

例子输出

	336

提示信息

整数有正有负,注意,不是求“绝对值”最大的乘积。
输入保证,如果按题目要求的乘法操作,不会使int发生溢出。

解题分析

目标是找到一个整数分割成三个部分后,这三个部分乘积的最大值。程序首先读取一个整数,但为了方便处理,它将这个整数作为字符串读入。这样可以轻松地在不同位置“切割”这个数字。

程序使用两个嵌套的循环来尝试所有可能的切割位置。第一个循环确定第一个乘号的位置,第二个循环确定第二个乘号的位置。每次循环都会根据这两个乘号的位置将数字分割成三部分。

分割后,程序将这三部分从字符串转换为长整型数字,然后计算这三个数字的乘积。程序会持续追踪遇到的最大乘积。在尝试了所有可能的分割方式后,程序输出找到的最大乘积值。

整个思路的核心是穷举法,即尝试所有可能的分割方式,然后找出其中乘积最大的一种。这种方法简单直接,适用于这个问题,因为整数的长度有限,所以可能的分割方式也是有限的。

代码实现

(方法一)c语言风格

#include <stdio.h>
#include <string.h>
#include <limits.h>
#include <stdlib.h>int main() {char temp[12],numStr[12]; // 假设输入的整数不超过10位int flag=0;scanf("%s", temp);if(temp[0]=='-'){flag=1;strcpy(numStr,temp+1);}else{strcpy(numStr,temp);}int len = strlen(numStr);long maxProduct = LONG_MIN;for (int i = 1; i < len; ++i) {for (int j = i + 1; j < len; ++j) {// 将字符串划分为三部分char part1[11], part2[11], part3[11];strncpy(part1, numStr, i);part1[i] = '\0';strncpy(part2, numStr + i, j - i);part2[j - i] = '\0';strcpy(part3, numStr + j);// 将字符串转换为整数并计算乘积long num1 = atol(part1);long num2 = atol(part2);long num3 = atol(part3);long product;if(!flag)product = num1 * num2 * num3;else product = -1*num1 * num2 * num3;// 更新最大乘积if (product > maxProduct) {maxProduct = product;}}}printf("%ld\n", maxProduct);return 0;
}

(方法二)c++风格

#include <iostream>
#include <string>
#include <climits>
using namespace std;// C++初始模板程序int main() {string num; cin>>num;int flag=0;if(num[0]=='-'){num=num.substr(1);flag=1;}int len=num.size(); long long int max=-INT64_MAX;for(int i=1;i<=len-2;i++){string temp1=num.substr(0,i);long long int n1=stoll(temp1);for(int j=1;j<len-i;j++){string temp2=num.substr(i,j);long long int n2=stoll(temp2);string temp3=num.substr(i+j);long long int n3=stoll(temp3);if(!flag)max=max>n1*n2*n3?max:n1*n2*n3;else{//cout<<n1<<" "<<n2<<" "<<n3<<endl;max=max>(-1)*n1*n2*n3?max:(-1)*n1*n2*n3;}}}cout<<max<<endl;return 0;
}

进一步拓展

strncpystrcpy 都是 C 语言标准库中的字符串处理函数,它们用于复制字符串,但在使用方式上有所不同。

strcpy

strcpy 函数用于将一个字符串复制到另一个字符串。它的原型如下:

char *strcpy(char *dest, const char *src);
  • dest:目标字符串的指针,用于存放复制的内容。
  • src:源字符串的指针。

strcpy 会将 src 指向的字符串(包括结束符 \0)复制到 dest 指向的位置。复制过程会覆盖 dest 原有的内容,并且在 src 字符串的结尾添加 \0 以确保 dest 是一个完整的字符串。

strncpy

strncpy 函数类似于 strcpy,但它允许指定最大复制长度。其原型如下:

char *strncpy(char *dest, const char *src, size_t n);
  • dest:目标字符串的指针。
  • src:源字符串的指针。
  • n:最多复制的字符数。

strncpy 会从 src 指向的字符串复制最多 n 个字符到 dest。如果 src 的长度小于 n,则 strncpy 会在 dest 之后添加额外的 \0 字符,直到总共复制了 n 个字符。如果 src 的长度大于或等于 n,则不会在 dest 的末尾添加 \0 字符。

使用注意事项

  • 当使用 strcpy 时,必须确保 dest 有足够的空间来存储 src 的内容,包括结尾的 \0 字符。否则可能会发生缓冲区溢出,导致不可预测的行为。
  • 在使用 strncpy 时,如果 n 小于 src 的长度,dest 将不会以 \0 结尾。这可能导致后续操作出现问题,因为大多数字符串处理函数都假设字符串是以 \0 结尾的。
  • 使用这些函数时需要特别注意目标字符串的大小,以避免溢出或未初始化的内存访问。

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

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

相关文章

yolov5 7.0版本部署手机端。通过pnnx导出ncnn。

yolov5 7.0版本部署手机端。通过pnnx导出ncnn。 流程配置ncnn android yolov5导出自己模型的ncnn修改yolo.py文件导出TorchScript文件pnnx转torchscript为ncnn 安卓运行权重路径输入输出anchors 大小类别名generate_proposals方法修改 结果 流程 网络yolov5 的部署已经有很多了…

最新最全的Postman接口测试: postman实现参数化

什么时候会用到参数化 比如&#xff1a;一个模块要用多组不同数据进行测试 验证业务的正确性 Login模块&#xff1a;正确的用户名&#xff0c;密码 成功&#xff1b;错误的用户名&#xff0c;正确的密码 失败 postman实现参数化 在实际的接口测试中&#xff0c;部分参数…

Redis Cluster

概念 Redis Cluster采用多主多从的方式&#xff0c;支持开启多个主节点&#xff0c;每个主节点可以挂载多个从节点。 Cluster会将数据进行分片&#xff0c;将数据分散到多个主节点上&#xff0c;而每个主节点都可以对外提供读写服务。这种做法使得Redis突破了单机内存大小的限制…

2023第二届全国大学生数据分析大赛AB题代码

看大家需求量比较大&#xff0c;所以更新了一下A、B题的示例代码&#xff0c;部分截图如下 A题部分截图 B题部分截图 免费获取代码 关注威信公众号 Python风控模型与数据分析&#xff0c;回复 23年数据分析大赛代码 文末查看如何免费获取代码&#xff1b;编写不易&#xff0c;…

低效的DOM操作(js的问题)

使用 JavaScript 操作DOM&#xff08;即添加、修改和删除元素&#xff09;是相对容易&#xff0c;但操作效率却不怎么样。 比如&#xff0c;每次添加一系列DOM元素。添加一个DOM元素是一个昂贵的操作。连续添加多个DOM元素的代码是低效的。 当需要添加多个DOM元素时&#xff…

【数据结构】AOV网与拓扑排序

一.AOV网的概念&#xff08;Activity On Vertex Network&#xff09; 在一个表示工程的有向图中&#xff0c;用顶点表示活动&#xff0c;用弧表示活动之间的优先关系。这样的有向图为顶点表示活动的网&#xff0c;我们称为AOV网&#xff08;Activity On Vertex Network&#xf…

scikit-learn线性回归法进行利润预测

大家好&#xff0c;生成式人工智能无疑是一个改变游戏规则的技术&#xff0c;但对于大多数商业问题来说&#xff0c;回归和分类等传统的机器学习模型仍然是首选。 私募股权或风险投资这样的投资者利用机器学习&#xff0c;首先必须了解关注的数据以及它是如何被使用的。投资公…

anaconda 笔记:安装anaconda之后显示conda command not found

解决方法是在.bashrc文件中添加如下一行文字&#xff08;如果没有.bashrc文件&#xff0c;就在root中新建一个这个文件&#xff09; export PATH$PATH:/home/Your_name/anaconda3/bin也就是安装anaconda3的路径 然后退出编辑&#xff0c;在命令行中敲入 source ~/.bashrc即可…

云原生Kubernetes系列 | init container初始化容器的作用

云原生Kubernetes系列 | init container初始化容器的作用 kubernetes 1.3版本引入了init container初始化容器特性。主要用于在启动应用容器(app container)前来启动一个或多个初始化容器,作为应用容器的一个基础。只有init container运行正常后,app container才会正常运行…

Spring——IOC,DI,AOP

Spring框架是一个轻量级的Java开发框架&#xff0c;它提供了许多功能强大的特性来简化Java应用程序的开发。其中&#xff0c;IOC&#xff08;控制反转&#xff09;、DI&#xff08;依赖注入&#xff09;和AOP&#xff08;面向切面编程&#xff09;是Spring框架的三大核心特性。…

k8s安装学习环境

目录 环境准备 配置hosts 关闭防火墙 关闭交换分区 调整swappiness参数 关闭setlinux Ipv4转发 时钟同步 安装Docker 配置Yum源 安装 配置 启动 日志 安装k8s 配置Yum源 Master节点 安装 初始化 配置kubectl 部署CNI网络插件 Node节点 检查 环境准备 准…

同步代码,异步代码-微任务 宏任务 事件循环(输出题)

1.知识点 事件循环&#xff1a; 由浏览器Web API管理的异步代码&#xff0c;如果有结果后&#xff0c;会根据这个异步代码的类型&#xff0c;被放入对应的微任务或宏任务当中。当执行栈的任务&#xff08;同步代码&#xff09;全部执行完毕后&#xff0c;再执行完所有微任务的…

springboot(ssm 二手图书交易系统 图书销售系统Java(codeLW)

springboot(ssm 二手图书交易系统 图书销售系统Java(code&LW) 开发语言&#xff1a;Java 框架&#xff1a;ssm/springboot vue JDK版本&#xff1a;JDK1.8&#xff08;或11&#xff09; 服务器&#xff1a;tomcat 数据库&#xff1a;mysql 5.7&#xff08;或8.0&#…

Google Guava 缓存工具使用详解

文章目录 缓存工具Cache接口LoadingCache接口CacheBuilder类CacheLoader类CacheStats类RemovalListener类 缓存工具 Guava提供了Cache接口和相关的类来支持缓存功能&#xff0c;它提供了高性能、线程安全的内存缓存&#xff0c;可以用于优化应用程序的性能。 特点&#xff1a…

Flutter 控件查阅清单

为了方便记录和使用Flutter中的各种控件&#xff0c;特写此博客以记之&#xff0c;好记性不如烂笔头嘛&#xff1a;&#xff09; 通过控件的首字母进行查找&#xff0c;本文会持续更新 控件目录 AAppBar BCContainerColumn &#xff08;列&#xff09; DDivider (分割线) EElev…

oj赛氪练习题,

区间内的真素数 import java.util.ArrayList; import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner new Scanner(System.in);int M scanner.nextInt();int N scanner.nextInt();scanner.close();ArrayList<Integer>…

Google Guava 散列工具使用详解

文章目录 散列哈希函数哈希码布隆过滤器 散列 Guava 提供了一组散列&#xff08;哈希&#xff09;相关的工具类和方法&#xff0c;包括哈希函数接口、哈希算法实现、哈希码&#xff08;HashCode&#xff09;类、布隆过滤器&#xff08;BloomFilter&#xff09;等等。 Guava 提…

【大连民族大学C语言CG题库练习题】——组合1

【问题描述】 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。 你可以按 任何顺序 返回答案。 【输入形式】 【输出形式】 【样例输入】 4 2 【样例输出】 [2,4] [3,4] [2,3] [1,2] [1,3] [1,4] 【样例说明】 【评分标准】 代码思路&a…

吴恩达《机器学习》11-1-11-2:首先要做什么、误差分析

一、首先要做什么 选择特征向量的关键决策 以垃圾邮件分类器算法为例&#xff0c;首先需要决定如何选择和表达特征向量 &#x1d465;。视频提到的一个示例是构建一个由 100 个最常出现在垃圾邮件中的词构成的列表&#xff0c;根据这些词是否在邮件中出现来创建特征向量&…

Java CompletableFuture使用示例

在我之前的文章IO密集型服务提升性能的三种方法中提到过&#xff0c;提升IO密集型应用性能有个方式就是异步编程&#xff0c;实现异步时一定会用到Future&#xff0c;使用多线程Future我们可以让多个任务同时去执行&#xff0c;最后统一去获取执行结果&#xff0c;这样整体执行…