关闭

猴年大吉之开心刷题

标签: 数学
697人阅读 评论(3) 收藏 举报
分类:
过年了,各种走亲访友,大吃大喝。为了不让自己忘了算法为何物,做了几道练手的题。

nyist 46 最少乘法次数

给你一个非零整数,让你求这个数的n次方,每次相乘的结果可以在后面使用,求至少需要多少次乘。如242*2=22(第一次乘),22*22=24(第二次乘),所以最少共2次;

分析:实际上那个指数是很大的,题目描述有问题。
#include <iostream>
#include <cmath>
#include <cstdio>
using namespace std;
const int N=5e6+10;
int p[N];
void init(){
    p[1]=0;
    p[2]=1;
    for(int i=3;i<N;i++){
        if(i&1) p[i]=p[i-1]+1;
        else p[i]=p[i/2]+1;
    }
}
int main()
{
    init();
    int t,n;
    scanf("%d",&t);
    while(t--){
        scanf("%d",&n);
        printf("%d\n",p[n]);
    }
    return 0;
}

nyist 1087 摆方格
大意:在N*N的方格中连续摆放数字,求左上至右下对角线的元素和最大值
分析:个人认为,此题不止2这个难度。
我们知道:小折线走法可以使得和最大。假设N=4,那么,有:

但是不能一直这样走。不然就不能够连续了。
故可以先填充好边界部分,留下小折线路线,最后自然形成最大值。
如:

N=5
19 20 1 2 3
18 21 22 5 4
17 16 23 6 7
14 15 24 25 8
13 12 11 10 9
N=4
16 1 2 3
15 14 13 4
10 11 12 5
9 8 7 6

发现规律:
有 
一共N-1项
再加上:

#include <iostream>
#include <cstdio>
using namespace std;
typedef unsigned long long LL;
int main()
{
    LL n;
    while(cin>>n){
        LL ans=(n-1)*n*n-(n-1)*(n-2)+(n*n-2*(n-2))/2;
        printf("%llu\n",ans);
    }
    return 0;
}

nyist 66 分数拆分
大意:输入一个正整数k,找到所有的正整数x>=y,使得1/k=1/x+1/y.
分析:做完此题,瞬间感觉到浮点数的强大。

#include <iostream>
#include <cstdio>
#include <cmath>
using namespace std;
const double eps=1e-7;
int main()
{
    int t,k;
    cin>>t;
    while(t--){
        scanf("%d",&k);
        for(int y=k+1;y<=2*k;y++){
            for(int x=y;;x++){
                double p1=1.0/k;
                double p2=1.0/x+1.0/y;
                if(fabs(p1-p2)<eps) {
                    printf("1/%d=1/%d+1/%d\n",k,x,y);
                }
                if(p1-p2>eps) break;
            }
        }
    }
    return 0;
}

nyist 743 复杂度
问:

for(i=1;i<=n;i++)

  for(j=i+1;j<=n;j++)

    for(k=j+1;k<=n;k++)

        operation;

你知道 operation 共执行了多少次吗

分析:规律题。i<j<k<……<
相当于在N个元素中取M个,这M个元素是递增的。即M个元素一旦选定,就只有一种情况,没有排列的情况。所以:C(n,m)
用素因子做居然Wa了。为什么。。。
WA:
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
typedef long long LL;
const LL mod=1009,N=2005;
LL pri[N],cnt;
bool vis[N];
void getpri(){
    for(LL i=2;i<N;i++){
        if(!vis[i]) pri[cnt++]=i;
        for(LL j=0;j<cnt&&i*pri[j]<N;j++){
            vis[i*pri[j]]=1;
            if(i%pri[j]==0) break;
        }
    }
}
LL getd(LL a,LL d){
    LL ans=0;
    while(a){
        a/=d;
        ans=ans+a;
    }
    return ans;
}
LL power(LL a,LL p){
    LL ans=1;
    a=a%mod;
    while(p>0){
        if(p&1) ans=ans*a%mod;
        a=a*a%mod;
        p>>=1;
    }
    return ans;
}
int main()
{
    getpri();
    LL n,m;
    while(cin>>m>>n&&(m+n)){
        LL ans=1;
        for(LL i=0;pri[i]<=n;i++){
            LL t1=getd(n,pri[i]),t2=getd(n-m,pri[i]),t3=getd(m,pri[i]);
            ans=ans*power(pri[i],t1-t2-t3)%mod;
        }
        printf("%d\n",ans);
    }
    return 0;
}

打表:
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
const int mod=1009,N=2005;
int dp[N][N];
void init(){
    for(int i=0;i<N;i++){
        dp[i][0]=dp[i][i]=1;
    }
    for(int i=2;i<N;i++){
        for(int j=1;j<i;j++){
            dp[i][j]=(dp[i-1][j-1]+dp[i-1][j])%mod;
        }
    }
}
int main()
{
    init();
    int n,m;
    while(cin>>m>>n&&(m+n)){
        printf("%d\n",dp[n][m]);
    }
    return 0;
}



0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

Python 刷题(想练python的可以对着刷一刷,持续更新)

这道题的意思是说
  • geniusluzh
  • geniusluzh
  • 2014-04-23 10:36
  • 7731

leetcode刷题经验

语言不是最重要的,思想最重要从做上面的题,我发现我更擅长一些数学技巧不高的程序题,习惯靠直觉立马书写代码,而非严格推理之后,再书写代码对于链表的题比较擅长,链表可以在纸上画画,关键要考虑的问题,就是链表指针在运算中会改变,如何保存需要保存的链表指针值是难点,除了那题拷贝具有random指针的链表题,...
  • basycia
  • basycia
  • 2016-02-28 15:31
  • 1392

谈谈程序员面试之刷题

前一段时间有一个非常有趣的故事(http://www.pingwest.com/sorry-cant-hire-you/  ),Max Howell (Homebrew的作者) 在 Google 面试时遇到了让人悲伤的情境,google拒绝了Max, 给出了答复:“我们90%的工程师都用你...
  • github_39335046
  • github_39335046
  • 2017-06-29 17:03
  • 1740

LeetCode刷题指南(一)

以下是我个人做题过程中的一些体会: 1. LeetCode的题库越来越大,截止到目前,已经有321个问题了。对于大多数人来说,没有时间也没有必要把所有题目都做一遍(时间充裕可以随意)。刷个100题左右应该就差不多了(可以考虑序号为前100多的题目,相对更经典一点)。 2. 从AC率高的开始做,难...
  • Lnho2015
  • Lnho2015
  • 2016-03-23 15:02
  • 38299

比较好的刷题网站推荐

http://www.cnblogs.com/DarrenChan/p/5648422.html 1.Leetcode鼎鼎大名的Leetcode,据不完全统计在上面被刷过的题可以围绕地球三圈。(没说赤道哈,就是这么严谨。)总之,很多国内外的码农在上面刷题。难度从easy到hard都有,...
  • dipolar
  • dipolar
  • 2017-03-09 11:56
  • 751

bzoj刷题(shui)记录

放假刷了一个月的水题,集中写一下题解吧。bzoj1858:线段树随便维护一下。 code bzoj2705:莫比乌斯反演裸题。 code bzoj1202:并查集,但是我写了一种跟floyd很像的奇怪的东西。 code bzoj1072:暴力。 bzoj2431:dp f[i][j]=su...
  • FZHvampire
  • FZHvampire
  • 2015-08-31 11:26
  • 1655

手把手教你用C++ 写ACM自动刷题神器(冲入HDU首页)

少年,作为苦练ACM,通宵刷题的你 是不是想着有一天能够荣登各大OJ榜首,俯瞰芸芸众生,唔....要做到这件事情可是需要一定天赋的哦! 博主本身也搞过一段时间的acm,对刷题深有感触,不信可以去看我博客的acm题解(哈哈)。
  • qq_28954601
  • qq_28954601
  • 2016-04-24 10:12
  • 2128

topcoder 刷题笔录 初级篇(一)

摘要:本系列文章为在topcoder上的刷题记录和心得,计划刷题500道。其中,初级题目30道,撰文三篇;中级题目60道,撰文六篇;其他高级题目100道,撰文10篇。 1.题目1——SRM146 DIV1(300‘) Problem Statement    ...
  • trochiluses
  • trochiluses
  • 2013-12-20 16:00
  • 2554

一、简单刷题APP(题库是Excel)之项目功能和效果图

这是本人的第一篇博客,自己也是菜鸟,如有不妥之处,欢迎指教,谢谢了。只是想借此机会自己也整理一下笔记。 在此想感谢各位牛人还有这个平台,我在学习和做项目的过程中遇到了很多问题,CSDN博客大都能解决我所遇到的问题,所以也希望自己能做一点点,可能帮助像我一样的菜鸟,虽然不一定有帮助,但是我会努力。1...
  • qq_35638837
  • qq_35638837
  • 2017-04-03 14:16
  • 699

操作系统刷题(一)

1.  UNIX操作系统是一种多用户分时操作系统,可用于PC机。 2.分时操作系统:是一种联机的多用户交互式的操作系统。一般采用时间片轮转的方式使一台计算机为多个终端服务。对每个用户能保证足够快的响应时间,并提供交互会话能力。 分时系统的特征:(1)同时性,计算机系统能被多个用户同时使...
  • alwaystry
  • alwaystry
  • 2017-06-03 22:47
  • 395
    个人资料
    • 访问:331291次
    • 积分:8856
    • 等级:
    • 排名:第2517名
    • 原创:575篇
    • 转载:13篇
    • 译文:0篇
    • 评论:36条
    我的链接
    最新评论