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

赣州高端网站开发网站建设的毕设报告

赣州高端网站开发,网站建设的毕设报告,注册公司后不营业有什么后果,卡盟网站制作目录 前言问题介绍解决方案代码编写java语言版本c语言版本c语言版本 思考感悟写在最后 前言 当前所有算法都使用测试用例运行过,但是不保证100%的测试用例,如果存在问题务必联系批评指正~ 在此感谢左大神让我对算法有了新的感悟认识! 问题介…

目录

  • 前言
  • 问题介绍
  • 解决方案
  • 代码编写
    • java语言版本
    • c语言版本
    • c++语言版本
  • 思考感悟
  • 写在最后

前言

当前所有算法都使用测试用例运行过,但是不保证100%的测试用例,如果存在问题务必联系批评指正~

在此感谢左大神让我对算法有了新的感悟认识!

问题介绍

原问题
给定字符串chars = [A,B…,Z],定义一个字符串和数字之间的关系
A, B, C, D…Z, AA, AB,…,AZ,BA, BB,BC,…BZ,AAA…ZZZ
1, 2, 3, 4, … 26, 27, 28, …52
问题一:给定一个字符串str,求出该字符串代表的数字
问题二:给定一个数字,求出该数字代表的字符串

解决方案

原问题
首先该问题通过k进制数是无法解决的,但是可以收到一些启发,使用伪进制数来解决问题
比如给定的字符集合chars = [A,B,C,D],那么该字符集合能够做出进制为4的伪进制数,相当于"逢E进一"
因此当给定一个str = BCBD时,求对应的数值,可以从高位开始计算进制转换即可
当给定一个数值时,分以下步骤计算:
1、计算数值需要多少位来存储,通过(数值/k^n)来找到n最大能够取到多少?
2、求出位数,后面循环填充每一位的数值即可,从高位开始计算,具体看代码

代码编写

java语言版本

原问题:
方法一:

    /*** 二轮测试:给定num,获取String的值* @param num* @return*/public static String num2StringCp1(int num, char[] chars) {if (num < 0 || chars == null || chars.length == 0) {return null;}int len = chars.length;// 先判断需要多少位存储int n = 0;while((int)(num / Math.pow(len, n))!= 0) {n++;}char[] res = new char[n];// 将所有位全部置为Afor (int i = 0; i < res.length; i++) {res[i] = 'A';num -= Math.pow(len, i);}// 此时num剩下的需要进行进制转换,从最高位开始判断for (int i = 0; i < res.length; i++) {int r = (int) (num/Math.pow(len, res.length-1 - i));res[i] += r;num -= r * Math.pow(len, res.length-1 - i);}return String.valueOf(res);}/*** 二轮测试:通过字符串获取num数字* @param str* @param chars* @return*/public static int string2Num(String str, char[] chars) {if (str == null || chars == null|| str.length() == 0 || chars.length == 0) {return 0;}int len = chars.length;char[] chars1 = str.toCharArray();int res = 0;for (int i = 0; i < chars1.length; i++) {int cur = chars1[i] - 'A' + 1;res += cur * Math.pow(len, chars1.length - 1 - i);}return res;}public static void main(String[] args) {System.out.println(string2Num("BABC", new char[]{'A', 'B', 'C'}));}

进阶问题

/*** 进阶问题:如果数组中存在一个1,如何能够最快的求得答案* @param arr* @return*/public static int unformSumCp3(int[] arr){if (arr == null || arr.length == 0) {return 0;}Arrays.sort(arr);int range = 0;for (int i = 0; i < arr.length; i++) {if (arr[i] > range+1) {return range+1;}else {range += arr[i];}}return range+1;}

c语言版本

正在学习中

c++语言版本

正在学习中

思考感悟

1、首先说一下字符串转数字的过程,这个过程其实很简单,确实跟进制转换是一致的只是没有0而已,A代表1,B代表2,计算出来结果没有问题
2、在说一下数字转字符串的问题,这个按照k^n最大不超过当前num的值的方式进行计算即可,整体来讲没有难度,就是需要对转换的原理熟悉一下

写在最后

方案和代码仅提供学习和思考使用,切勿随意滥用!如有错误和不合理的地方,务必批评指正~
如果需要git源码可邮件给2260755767@qq.com
再次感谢左大神对我算法的指点迷津!

http://www.yayakq.cn/news/297713/

相关文章:

  • 徐州丰县建设局网站查企业网站
  • .net网站程序北京网站报价
  • 一个dede管理两个网站正能量网站入口免费安全
  • 用ps做网站的临摹哪个网站有做兼职的
  • 有趣网站之家免费下载网站设计方案
  • 规划网站站点需要遵循哪些原则房地产公司
  • 河北省建设环境备案网站html商业网站模板
  • 电子商务网站模板 html佛山网红
  • 基于html5的旅游网站开发一般注册公司多少钱
  • 光谷中心城建设投资有限公司网站程序开发工程师
  • 交互式多媒体网站开发wordpress如何上传mp3
  • 四川建设行业数据共享平台的网站无锡网站制作哪家强
  • 银医网站建设方案wordpress商城 中文站
  • 中小企业网站建设应该注意什么佛山有什么网站
  • 招聘网站排名企业网网站
  • 做信誉认证对网站有什么好处网络规划设计师和信息系统项目管理师哪个好考
  • 网站怎么加二级域名常州网站制作价格
  • 怎样做移动端网站网站网页设计海报图片
  • 南县网站定制自己做网站什么网站比较好
  • 品牌seo是什么seo资料
  • 中国农村建设投资有限公司网站首页网站建设安全协议
  • 做网站申请个体户建立视频网站
  • php网站视频代码做视频特技的网站
  • 服务范围 网站建设公司灵璧零度网站建设
  • 做代码和网站有免费的网站做农家院宣传
  • 网站建设知识及维护技巧淮北网站开发公司
  • 黄冈网站官方登录平台做网站需要什么硬件环境
  • 网站前台怎么做手机论坛网站模板
  • 网站用户角色网络架构如何写
  • 网站商城注意事项软件商店正版下载安装