最近,博客园上看到有关求 斐波那契数列的第n位是什么的问题。什么是 斐波那契数列? 我自己也忘记了,后来百度了下。http://baike.baidu.com/view/816.htm?fr=aladdin

现在,了解了什么是 斐波那契数列,到底是什么东西的问题便好做了,不管你是用递归做,还是for 循环,都比较容易想到该如何下手。

可是,问题往往没那么简单。 我在看到这个问题的第一个反应就是——当 int 保存的类型,超出最大值范围后,便得不到自己想求的数值了。

接着可能有人会想到  使用decimal  ,可是,经过测试,使用decimal保存的范围也达不到要求(当求第135位左右的时候,超出了可以保存的范围)。

后来想到使用字符串保存第n位数值,进行模拟整数进行计算。 使得尽可能求得更大的范围(尽管这种方式,也受到了,保存的最大字符串个数的限制,但获取范围却大大改善)。

如果有人有更好的方式,欢迎交流。好了,说了那么多,说下具体思路:

1.  使用一个 字符串 string a1保存 第 (n-2)位的数值。(n>=3)

2.使用  string a2 保存 第 (n-1)位的数值。

3.  获取 a1 a2 的最末尾的数值(看成整数的时候也就是个位数)进行相加, 得到两值相加的和。(此时其中一个为进位,一个为最终值得个位数)

4.循环获取   a1 a2 的相同位置 (末尾-1)   的数值和进位进行相加。

5.  求第n位的数值,就循环 1至4 的步骤。

说白了,也就是模拟我们动手用笔,进行计算两个数值相加的过程。

好了废话不多说,直接上代码。

 private string Plusstring(string str2, string str1)//str1  为字符串个数最多的数值
{ string value = "";
int max = (str1.Length - > str2.Length - ) ? str1.Length - : str2.Length - ; // 较大的字符串个数 int forward = ;// 进位
int k = str2.Length - ; // 较短的字符串
int intvalue = ;
for (int i = max; i > -; i--)
{
if (k > -)
{
intvalue = int.Parse(str1[i].ToString()) + int.Parse(str2[k].ToString()) + forward;// 相同位置的数值相加 所以 intvalue 最大为 9+9+1
k--;
}
else
{
intvalue = int.Parse(str1[i].ToString()) + forward;
}
string strvalue = intvalue.ToString();
value = value.Insert(, strvalue[strvalue.Length - ].ToString());
if (strvalue.Length == ) // 两个数值相加 , 只有一位则 下一个进位 为0 ;
{
forward = ;
}
else
{
forward = int.Parse(strvalue[].ToString());
}
} if (forward != )// 计算完毕,如果进位为0,跳过最高位的进位,否则补回最高位
{
value = value.Insert(, forward.ToString());
}
return value;
}

是通过使用以下代码调用上面的代码进行计算的 。 使用 winform  在上面拖一个 button,一个 textbox

  private void button1_Click(object sender, EventArgs e)
{ int n = int.Parse(textBox1.Text.Trim()); // 获取输入第几位
string str1 = "", str2 = "", str3 = "";
decimal a1 = ;
decimal a2 = ;
decimal an = ;
for (int i = ; i < n; i++) // 此处直接计算第三位 之后的数值,第一第二位就不在此增加代码了。
{ // an = a1 + a2;// 此处为使用decimal 与前 130为的数值进行比较看计算出来的数值是否正确。
// a1 = a2;
// a2 = an; str3 = Plusstring(str1, str2);
str1 = str2;
str2 = str3; } MessageBox.Show(string.Format(" n={0}, an={1} , str={2}", n, an, str3)); }

经过测试,很轻松的就计算了  第 1000 位的数值,有木有?  我也试过了计算 第一万位的, 耗时有点长,但还是计算出了结果。十万位的似乎过了半个小时都没算出来。

使用类似的方式,可以计算,什么 1!+2!+。。。+n!    的算法。   相对应的乘法,减法, 只需要在上面的基础上修改一点即可。

可是毕竟还是存在一些问题,这只是扩展了 比较大的范围而已。

例如:

1. 如果我想计算中的数值中, 保存的字符  str1.Length> int.Max 的时候。  便无法正确计算了。

2. 计算除法的时候,一时没想到好的办法,只记得 高中的知识中, 也有类似的方式可以在乘法的基础上进行,计算除法

有关求第n位xxx 的算法的问题的更多相关文章

  1. 一种快速求fibonacci第n个数的算法

    利用动态规则的思路,摒弃传统的递归做法,可以得到一种快速的求fibonacci第n个数的算法: ''' 求第n(从1开始)位fibonacci数 fibonacci数列前两位为0, 1. 后面每一位数 ...

  2. Hihocder 1639 : 图书馆 (组合数+唯一分解 求最后一位)(妙)

    给定n,(n<=10^3),然后输入n的数a[i],(a[i]<=1e10),求ans=(a1+a2+a3...an)! / (a1!*a2!*a3!...an!) 的结果的最一位数. 适 ...

  3. ipv4 ipv6 求字符串和整数一一映射的算法 AmazonOrderId

    字符串和整数一一映射的算法 公司每人的英文名不同,现在给每个英文名一个不同的数字编号,怎么设计? 走ipv4/6  2/32 2/128就够了,把“网段”概念对应到“表或库”,ip有a_e5类,这概念 ...

  4. Java蓝桥杯练习题——求小数n位后3个数

    求整数除法小数点后第n位开始的3位数 位数不足的补0,如0.125小数第3位后三位:0.12500→500 输入格式:a b n,空格分开,a是被除数,b是除数,n是小数后的位置 输出格式:3位数字, ...

  5. [转载]求平方根sqrt()函数的底层算法效率问题

    我们平时经常会有一些数据运算的操作,需要调用sqrt,exp,abs等函数,那么时候你有没有想过:这个些函数系统是如何实现的?就拿最常用的sqrt函数来说吧,系统怎么来实现这个经常调用的函数呢? 虽然 ...

  6. 相辅相成的求最单源短路径算法:(SPFA& dijkstra)

    引用一位老oier的话: 一道题如果边权没有负数,那么一定是在卡SPFA.这时候就用到了堆优化的Dijkstra; 写在前面: 多打代码! 最好都掌握,灵活变通 SPFA: 主要用于稀疏图和有负权边的 ...

  7. HDU 1025 Constructing Roads In JGShining's Kingdom(求最长上升子序列nlogn算法)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1025 解题报告:先把输入按照r从小到大的顺序排个序,然后就转化成了求p的最长上升子序列问题了,当然按p ...

  8. 算法导论(第三版) Exercises4.2(求最大和子数组的算法优化过程)

    4.1-1 如所有元素都为负,则返回所有元素中最大的负数. 4.1-2(暴力法求最大和子数组) struct subarray { int start, end, sum; }; void brute ...

  9. ZOJ 1542 POJ 1861 Network 网络 最小生成树,求最长边,Kruskal算法

    题目连接:problemId=542" target="_blank">ZOJ 1542 POJ 1861 Network 网络 Network Time Limi ...

随机推荐

  1. Spring之27:BeanDefinitionRegistry

    关于BeanDefinition见<Spring之Ⅰ:BeanDefinition> BeanDefinitionRegistry的类图: BeanDefinition 的注册接口,如 R ...

  2. 剑指offer50:数组中重复的数字

    1 题目描述 在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一个重复的数字. 例如,如果输入长 ...

  3. css特效实现透明渐变

    知乎发现栏目上的标题图一般都是以下图方式展现的,很显然它是利用渐变去实现的.思路很有意思,主要是要有两方面的认知: 这张图其实可以分成两部分,右边控制图形和渐变,左边就是一张纯色背景,和渐变无关 透明 ...

  4. 如何实现在H5里调起高德地图APP

    这一篇文章将告诉您,如果直接打开高德地图APP,并展示路线规划.适合有定位的移动设备,可以查询到从“我的位置”到目的地的路径规划,并直接导航. 场景二.调起高德地图的路线规划功能 导航是目前JSAPI ...

  5. Web Scraper 翻页——控制链接批量抓取数据(Web Scraper 高级用法)| 简易数据分析 05

    这是简易数据分析系列的第 5 篇文章. 上篇文章我们爬取了豆瓣电影 TOP250 前 25 个电影的数据,今天我们就要在原来的 Web Scraper 配置上做一些小改动,让爬虫把 250 条电影数据 ...

  6. Java定时任务工具详解之Timer篇

    Java定时任务调度工具详解 什么是定时任务调度? ◆ 基于给定的时间点,给定的时间间隔或者给定的执行次数自动执行的任务. 在Java中的定时调度工具? ◆ Timer       ◆Quartz T ...

  7. vscode IIsExpress用法

    最近前端调试项目,都要安装IIS,使用IIS Express插件不需要另外在IIS架设站点,方便使用 1.安装IIS Express插件 2.ctrl+shfit+p 启动IIS Express 命令 ...

  8. h5 点击ios键盘完成 出现键盘大小的白块

    document.addEventListener('focusout', function (e) { window.scrollTo() }) 源文件链接 https://blog.csdn.ne ...

  9. 高性能的js第三方库——lodash、 Underscore、async、md5及moment

    背景:为了实现某些功能,如:数据排序.分组.筛选.深拷贝等,自己写的函数或网上搜索处理的转换函数质量无法保证,这时直接使用成熟的js第三方库是首选. *注:“framework(框架)”,“libra ...

  10. 虚拟机安装master,克隆slave0、slave1(多台机相连,网络匹配)

    1.在虚拟机中创建一个名叫master的主机 2.创建成功后,打开编辑选项——虚拟网络网络编辑器,填网关 3.打开终端,进入root权限,编写命令 设置虚拟机DNS 4.给master网络配置好后,克 ...