当前位置: 首页 > news >正文

怎么做刷业务网站关于建设校园网站申请

怎么做刷业务网站,关于建设校园网站申请,国外开源 企业网站,我国网站开发2578. 最小和分割 - 力扣(LeetCode) 给你一个正整数 num ,请你将它分割成两个非负整数 num1 和 num2 ,满足: num1 和 num2 直接连起来,得到 num 各数位的一个排列。 换句话说,num1 和 num2 中所…

2578. 最小和分割 - 力扣(LeetCode)


给你一个正整数 num ,请你将它分割成两个非负整数 num1 和 num2 ,满足:

  • num1 和 num2 直接连起来,得到 num 各数位的一个排列。
    • 换句话说,num1 和 num2 中所有数字出现的次数之和等于 num 中所有数字出现的次数。
  • num1 和 num2 可以包含前导 0 。

请你返回 num1 和 num2 可以得到的和的 最小 值。

注意:

  • num 保证没有前导 0 。
  • num1 和 num2 中数位顺序可以与 num 中数位顺序不同。


思路分析总结来自:(https://leetcode.cn/problems/split-with-minimum-sum/)

  • 1.满足nums1 和 nums2的位数小于<= bit_len(num) / 2 尽可能最短
  • 2.依次给nums1 和 nums2 分配较小的数给高位

(1)用一个 nums数组 来存放num的各个位的数字,然后 sort排序,再根据思路分析将其转化为num1 num2

class Solution {
public:int splitNum(int num) {vector<int> nums;while(num){nums.push_back(num%10);num = num / 10;}sort(nums.begin(),nums.end());int num1=0,num2=0;for(int i=0;i<nums.size();i++) {if(i%2==0) num1 = num1 * 10 + nums[i];else num2 = num2 * 10 + nums[i];}return num1 + num2;}
};

这段文字来自这篇博客:位运算&1,」」1,「「1

n&1 就是判断 n 是否为奇数.

  • n 为奇数时,对应的二进制数最低位一定为1,n&1的结果就是1。
  • n为偶数时,相应的最低位为0,n&1的结果就是0。
  • n&1 ==1 或者写 n%2 == 1 或者写 n%2

可以将i%2 == 1 写成 i&1

class Solution {
public:int splitNum(int num) {vector<int> nums;while(num){nums.push_back(num%10);num = num / 10;}sort(nums.begin(),nums.end());int num1=0,num2=0;for(int i=0;i<nums.size();i++) {if(i&1) num2 = num2 * 10 + nums[i];else num1 = num1 * 10 + nums[i];}return num1 + num2;}
};

(2) 将num先转成字符串,接着根据思路分析,拼接两个字符串s1和s2,最后转成int,相加后返回

class Solution {
public:int splitNum(int num) {string s = to_string(num);sort(s.begin(),s.end());string s1,s2;for(int i=0;i<s.size();i++) {// if(i&1) s2 += s[i];// else s1 += s[i];i&1?s2 += s[i] : s1 += s[i];}return stoi(s1) + stoi(s2);}
};

(3)将num先转成字符串,接着根据思路分析,获得num1和num2,相加后返回

class Solution {
public:int splitNum(int num) {string s = to_string(num);sort(s.begin(),s.end());int num1=0,num2=0;for(int i=0;i<s.size();i++) {// if(i&1==1) num2 = num2 * 10 + s[i]-'0';// else num1 = num1 * 10 + s[i]-'0';i&1? num2 = num2 * 10 + s[i]-'0' : num1 = num1 * 10 + s[i]-'0';}return num1 + num2;}
};

(4)将(3)进行进一步优化,省去三目运算

class Solution {
public:int splitNum(int num) {string s = to_string(num);sort(s.begin(),s.end());int a[2]{};for(int i=0;i<s.size();i++) {// a[i % 2] = a[i % 2] * 10 + s[i] - '0'; a[i&1] = a[i&1] * 10 + s[i]-'0';}return a[0] + a[1];}
};
  • 时间复杂度:O(mlog⁡m),其中 m 为 num 转成字符串后的长度。
  • 空间复杂度:O(m)
http://www.yayakq.cn/news/74554/

相关文章:

  • 网站搜索功能怎样做如何建设网站服务器
  • 重庆市城市建设档案馆官方网站房地产政策最新消息
  • 做品牌网站多用户智能网站建设源码
  • 折叠网站开发工程师极简网站模板
  • 自己做卖东西的网站网站建设先进个人
  • 什么网站做h5不收费产品开发
  • 工商网站wordpress 爆路径
  • 美妆网站源码asp有什么网站可以叫人做图
  • 长春网站制作顾问h5页面用什么软件
  • 印刷厂网站建设方案怎么免费的安装wordpress主题
  • 陕西示范校建设专题网站wordpress分类页面模板
  • 江西网站开发公司电话物业公司网站模板
  • 秦皇岛和平大街网站建设求一个dw做的网站
  • 响应式网站建设信息建设网站基础知识
  • 深圳网站建设公司乐云seo598公司商标设计图
  • 图库下载网站源码模板网站如何建站
  • 河北建设协会官方网站网页制作的代码
  • 番禺区建站服务商花生壳免费域名注册网站
  • 东莞网站建设 石化泰州学习网站建设
  • access如何与网站连接数据库毕业设计网站建设体会
  • 网站空间就是服务器吗关键词你们懂的
  • 百度站长收录免费商城网站模板下载
  • 做性的网站自己的主机做服务器网站如何备案
  • 培训网站建设公司天津网页制作网页报价
  • 精品网站建设费用 地址磐石网络站长工具
  • 台州网站建设制作网站建设托管公司
  • 345诛仙网站是谁做的php购物网站开发uml图
  • 网站的内容与功能设计写网站论文怎么做
  • 企业网站初始期如何优化怎么找电商卖自己的产品
  • 鲜花网站建设的项目介绍德阳北京网站建设