当前位置: 首页 > 编程日记 > 正文

uva 10183 How many Fibs?

数学题:

给你一个区间[a,b]在该区间内有多少个费波那列数(包括a,b),数据规模达到10^100。

这题的原理很简单,基本没什么算法,其实更偏重于编程能力,需要用到高精度。另外找区间的地方要小心

1.先把长度在100以内的fibs先找出来并保存,再开始输入case

2.得到区间[a,b],那么在保存下来的fibs里找到  第一个f[p],要满足a<=f[p] , 然后继续找下去,找到  第一个f[q],满足b<=f[q]

其中f[q]还要处理一下,如果b=f[q],那么f[q]显然在区间内 ; b<f[q],那说明f[q]并不在区间内,由于是第一个所以可以知道f[q-1]一定要区间内而且f[q-1]<b , 处理后就可以得到准确的q值

最后答案就是q-p+1

代码又写得不好,最近脑袋比较乱写出来的代码都很乱

//构建10^100以内的fibs数
#include <cstdio>
#include <cstring>
#define LEN 150
#define MAX 510
struct fibs
{int a[LEN],len;
}f[MAX];int find(struct fibs x ,struct fibs y) 
{//当x<y为1,x>y为-1,相等为0if(x.len < y.len)      return 1;else if(x.len > y.len) return -1;int i=x.len-1 , j=y.len-1;while(i>=0){if(x.a[i] < y.a[j]) return 1;else if(x.a[i] > y.a[j])  return -1;i--; j--;}return 0;
}
void add(int x ,int y ,int m)  //f[x]>f[y]
{int t,c=0;for(int i=0; i<f[x].len; i++){t=f[x].a[i]+f[y].a[i]+c;f[m].a[i]=t%10;c=t/10;}f[m].len=f[x].len;if(c){f[m].a[f[m].len]=c;f[m].len++;}return ;
}
void init()
{memset(f,0,sizeof(f[0]));f[1].a[0]=1;  f[1].len=1;f[2].a[0]=2;  f[2].len=1;int i=3;do{add(i-1,i-2,i);if(f[i].len>=101) break;i++;}while(1);//printf("count=%d  len=%d\n",i,f[i].len);return ;
}
int main()
{init();char s1[LEN],s2[LEN];struct fibs a,b;while(scanf("%s%s",s1,s2)!=EOF){if(!strcmp(s1,"0") && !strcmp(s2,"0")) break;a.len=strlen(s1);  b.len=strlen(s2);int i,j,p,q,t;for(i=0,j=a.len-1; i<a.len; i++,j--)a.a[j]=s1[i]-'0';for(i=0,j=b.len-1; i<b.len; i++,j--)b.a[j]=s2[i]-'0';//for(i=0; i<a.len; i++) printf("%d",a.a[i]); printf("\n");//for(i=0; i<b.len; i++) printf("%d",b.a[i]); printf("\n");
 i=1;while(1){    t=find(a,f[i]);if(t==1 || t==0) break;i++;}p=i;while(1){t=find(b,f[i]);if(t==1 || t==0) break;i++;}if(t==1) q=i-1;else     q=i;//printf("p=%d   q=%d\n",p,q);//for(int i=f[p].len-1; i>=0; i--) printf("%d",f[p].a[i]); printf("\n");//for(int i=f[q].len-1; i>=0; i--) printf("%d",f[q].a[i]); printf("\n");printf("%d\n",q-p+1);}return 0 ;
}

转载于:https://www.cnblogs.com/scau20110726/archive/2013/01/22/2872273.html

相关文章:

2018/11/29 一个64位操作系统的设计与实现 02 (安装nasm)

操作系统: Centos7 在nasm官网上的到通过yum安装nasm的方法 首先在/etc/yum.repos.d/目录下 新建一个名为nasm.repo的文件, 在这么文件中写入内容如下 : [nasm] nameThe Netwide Assembler baseurlhttp://www.nasm.us/pub/nasm/stable/linux/ enabled1 gpgcheck0[nasm-testing]…

a-awk 计算数值最大,最小,平均值并保留指定位数

awk 计算最大值 echo -e "1\n2\n3\n10\n9\n5\n11\n"|awk BEGIN {max 0} {if ($1>max) max$1 } END {print "Max", max} 输出为&#xff1a;Max 11 或者可以使用sort命令更为便捷&#xff1a; cho -e "1\n2\n3\n10\n9\n5\n11\n"|sort -n |tai…

第18章:MYSQL分区

第18章&#xff1a;分区 目录 18.1. MySQL中的分区概述18.2. 分区类型18.2.1. RANGE分区18.2.2. LIST分区18.2.3. HASH分区18.2.4. KEY分区18.2.5. 子分区18.2.6. MySQL分区处理NULL值的方式18.3. 分区管理18.3.1. RANGE和LIST分区的管理18.3.2. HASH和KEY分区的管理18.3.3. 分…

mysql属性配置提高查询_MYSQL性能优化-安装时优化参数配置提高服务性能

MYSQL性能优化一直是个头痛的问题&#xff0c;目前大多都是直接把页面html静态页面或直接使用了缓存技术&#xff0c;下面我就mysql本身的性能优化来分享一下。安装时优化参数配置提高服务性能在Linux下安装Mysql采用默认配置安装的Mysql却未必是工作在最佳性能状态的&#xff…

c++引用的自我见解

2019独角兽企业重金招聘Python工程师标准>>> 刚开始学习c 学完指针后&#xff0c;其细节比较好明白&#xff0c;但学到引用了以后&#xff0c;只知其表却不知其底层的实现机制&#xff0c;虽然知道引用是别名、声明必须同时初始化等等&#xff0c;但这只是概念性的东…

c# yield关键字原理

https://www.cnblogs.com/blueberryzzz/p/8678700.html c# yield关键字原理详解 1.yield实现的功能yield return&#xff1a;先看下面的代码&#xff0c;通过yield return实现了类似用foreach遍历数组的功能&#xff0c;说明yield return也是用来实现迭代器的功能的。 using st…

linux进程间通信:命名管道FIFO

文章目录FIF&#xff2f; 通信特点系统调用接口应用拥有亲缘关系之间的进程通信非亲缘关系进程之间的通信总结FIF&#xff2f; 通信特点 FIFO文件有文件名 可以像普通文件一样存储在文件系统之中可以像普通文件一样使用open/write读写和pipe文件一样属于流式文件&#xff0c;不…

mysql 账户管理_如何用MySQL 命令来实现账户管理

今天我们要学习的是如何用MySQL 命令的方式来对账号进行管理&#xff0c;我们大家都知道在实际应用中MySQL 命令可以完成多种任务&#xff0c;以下的文章主要是对用MySQL 命令的方式来对账号进行管理的具体内容介绍。手册上说 “GRANT语句允许系统管理员创建MySQL用户账户&…

Can't connect to MySQL server on '127.0.0.1' (10061) (code 2003)解决方法

先验证一下MySQL的服务是否开启&#xff0c;到计算机->管理->服务和应用程序->服务 如果服务已开启&#xff0c;就检查一下C:\WINDOWS\system32\drivers\etc目录下的hosts文件&#xff0c; 是否存在这一下&#xff0c;不存在添加。 最后在mysql的配置文件my.ini中[mys…

学习MongoDB (1) :配置安装

为什么80%的码农都做不了架构师&#xff1f;>>> MongoDB是一种强大、灵活、可扩展的数据存储方式。它扩展了关系型数据库的众多有用的功能&#xff0c;如辅助索引、范围查询、排序。 最近开始在Windows 32位平台下研究MongoDB的使用&#xff0c;为了方便&#xff…

跨域策略文件crossdomain.xml文件

使用crossdomain.xml让Flash可以跨域传输数据 一、crossdomain.xml文件的作用 跨域&#xff0c;顾名思义就是需要的资源不在自己的域服务器上&#xff0c;需要访问其他域服务器。跨域策略文件是一个xml文档文件&#xff0c;主要是为web客户端(如Adobe Flash Player等)设置跨…

linux进程间通信:FIFO应用 /var/log/ 系统日志的模拟实现

在类unix操作系统下存在这样一个目录/var/log/&#xff0c;主要是记录操作系统相关的系统各个进程服务的日志信息 该日志系统的特性如下&#xff1a; 支持多进程并发写入同一文件不同进程日志信息可以写入不同文件支持使用head/tail/grep/cat/vi 等命令进行日志操作 我们可以…

context.xml mysql_在tomcat下context.xml中配置各种数据库连接池(示例代码)

Tomcat6的服务器配置文件放在 ${tomcat6}/conf 目录底下。我们可以在这里找到 server.xml 和 context.xml。当然&#xff0c;还有其他一些资源文件。但是在在本文中我们只用得上这两个&#xff0c;其他的就不介绍了。1,首先&#xff0c;需要为数据源配置一个JNDI资源。我们的数…

Planetary.js:帮助你构建超炫的互动球体效果

Planetary.js 是一个 JavaScript 库&#xff0c;用于构建互动球体效果。它使用 D3 和 TopoJSON 解析和渲染地理数据。Planetary.js 采用了基于插件的架构&#xff0c;即使是默认的功能是作为插件实现的&#xff0c;这使得 Planetary.js 非常灵活。Planetary.js 是完全可定制&am…

JAVA条件表达式的陷阱

Map<String, Integer> map new HashMap<String, Integer>(); map.put("count", null); Integer it map null ? 0 : map.get("count"); 注意&#xff1a;在第三行&#xff0c;会抛出java.lang.NullPointerException信息。因为分析&…

腾讯Bugly异常崩溃SDK接入

首先登入Bugly&#xff0c;创建应用&#xff0c;记录下AppId ①下载SDK&#xff0c;通过Cocoapods集成 pod Bugly #腾讯异常崩溃日志服务 ②导入头文件&#xff0c;并初始化 /** 腾讯Bugly */#import <…

linux进程间通信:FIFO实现进程间的双向通信

fifo的双向通信的方式如下图&#xff1a; 两个进程间的通信需要两个命名管道&#xff0c;分别处理一个进程的读和写 导致这种通信方式出现的根因还是由于fifo的阻塞读和阻塞写&#xff0c;所以这里需要使用两个管道对读写进行分别处理。 同时因为管道传输的数据为流式数据&…

load python txt文件_详解Python中numpy.loadtxt()读取txt文件

为了方便使用和记忆&#xff0c;有时候我们会把 numpy.loadtxt() 缩写成np.loadtxt() ,本篇文章主要讲解用它来读取txt文件。读取txt文件我们通常使用 numpy 中的 loadtxt()函数numpy.loadtxt(fname, dtype, comments#, delimiterNone, convertersNone, skiprows0, usecolsNone…

线程之线程标识

就像每个进程有一个进程ID一样&#xff0c;每个线程也有一个线程ID。进程ID在整个系统中是唯一的&#xff0c;但线程ID不同&#xff0c;线程ID只在它所属的进程环境中有效。 进程ID&#xff0c;用pid_t数据类型来表示&#xff0c;是一个非负整数。线程ID则用pthread_t数据类型来…

Tab Bar Animation

2019独角兽企业重金招聘Python工程师标准>>> 自定义UITabBar。自定义Tab Bar切换过程中的动画效果。用户点击某个Tab&#xff0c;一个小箭头会从之前的Tab上面移动到当前点击的Tab上面。可以在tab上面加上小箭头用于显示当前处于哪个tab。 Code4App编译测试&#xf…

CynosDB技术详解——存储集群管理

本文由腾讯云数据库发表 前言 CynosDB是架构在CynosFS之上的分布式关系数据库系统&#xff0c;为最大化利用存储资源&#xff0c;平衡资源之间的竞争&#xff0c;检查资源使用情况&#xff0c;需要一套高效稳定的分布式集群管理系统&#xff08;SCM: Storage Cluster Manager&a…

linux进程间通信:system V消息队列

文章目录基本介绍编程接口代码实例消息队列的发送和接收消息队列中的消息对象的属性控制基本介绍 支持不同进程之间以消息&#xff08;messages&#xff09;的形式进行数据交换&#xff0c;消息能够拥有自己的标识&#xff0c;且内核使用链表方式进行消息管理。进程之间的通信…

将一个一维数组转化为二进制表示矩阵。例如_算法之矩阵最大区域问题

例如&#xff1a;给定一个m*m(0<n)的矩阵&#xff0c;请找到此矩阵的一个子矩阵&#xff0c;并且此子矩阵的各个元素的和最大&#xff0c;输出这个最大的值。或者给出一个柱形矩阵求最大子矩阵的最大值。首先我们需要了解一下最大字段和问题。最大子段和问题给定一个长度为n…

伪元素first-letter

用于设置一个块级元素首位字符的样式&#xff0c;而且仅对该字符设置样式 p&#xff1a;first-letter{ font-size&#xff1a;200%}是让P中的第一个字符是其他字符大小的两倍转载于:https://www.cnblogs.com/damade/p/3518583.html

fedora17 的 rc.local

Fedora17上已经找不到/etc/rc.local了&#xff0c;如果我们想开机执行某个脚本&#xff0c;就需要手动创建这个文件&#xff0c;目录也发生了小小变化&#xff1a; 1. 新建文件/etc/rc.d/rc.local&#xff0c;第一行须指明执行shell&#xff1a; [root www.linuxidc.com rc.d]#…

使用TortoiseGit,设置ssh方式连接git仓库。

开始设置之前的准备&#xff1a;建立项目文件夹&#xff0c;初始化git仓库(右键 git init)&#xff0c;右键打开 git bash &#xff0c;git pull “仓库地址”, 把网站上的仓库代码拉取下来。 TortoiseGit使用扩展名为ppk的密钥&#xff0c;而不是ssh-keygen生成的rsa密钥。 也…

linux进程间通信:消息队列实现双端通信

双端通信描述 利用消息队列针对发送接受消息的类型唯一性 进行多个客户端之间消息传递&#xff0c;而不需要server端进行消息转发。 同时消息队列的读阻塞和写阻塞特性&#xff08;消息队列中已经写入数据&#xff0c;如果再不读出来&#xff0c;则无法再次写入&#xff09;让…

windows 软件安装事件_苹果安装windows,报windows支持软件未能存储到所选驱动器

今天去给一个IT外包客户维修电脑&#xff0c;前台的一台苹果电脑需要安装双系统&#xff0c;苹果电脑安装双系统对我们专业安装系统工程师来说&#xff0c;这不是很简单的嘛&#xff01;客户问需要多长时间&#xff0c;信心满的说一到两个小时&#xff01;客户说那你开始弄吧。…

C# Attribute简介

一 、EventAttribute有&#xff1a; BrowsableAttribute 、CategoryAttribute、DescriptionAttribute、DefaultEventAttribute PropertyAttribute有&#xff1a; BrowsableAttribute 、CategoryAttribute、DescriptionAttribute、 DefaultPropertyAttribute、DefaultValueAttri…

P2P之UDP穿透NAT的原理

关键词: P2P UDP NAT 原理 穿透 Traveral Symmetric Cone原始作者: Hwycheng Leo(FlashBTHotmail.com)源码下载: http://bbs.hwysoft.com/download/UDP-NAT-LEO.rar参考&#xff1a;http://midcom-p2p.sourceforge.net/draft-ford-midcom-p2p-01.txt P2P之UDP穿透NAT的原理…