吉大考研机试2010年题目

题目一(jobdu1478:三角形的边)、    http://ac.jobdu.com/problem.php?pid=1478

给出三个正整数,计算最小的数加上次小的数与最大的数之差。

题目分析:

简单题。能够用非常多方法解决

AC代码:

#include<iostream>
using
namespace
std;
int
main()
{
    int
a,b,c,ma;
    while(cin>>a>>b>>c){
        ma=0;
        if(a==0)
break;
        if(ma<a) ma=a;
        if(ma<b) ma=b;
        if(ma<c) ma=c;
        cout<<(a+b+c)-2*ma<<endl;
    }
    return
0;
}



题目二(jobdu1476:平方因子)、
   

pid=1476">
http://ac.jobdu.com/problem.php?pid=1476


    给定一个数n,判定它是否有一个不为1的全然平方数因子。

也就是说。是否存在某个k。k>1。使得k*k可以整除n。

题目分析:

数字记录全部平方数,在小于n的情况下进行測试就可以。

AC代码:

/**
 *简单模拟
 */
#include<iostream>
#include<string>
using
namespace
std;
int
main()
{
    int
n,a[101];
    for(int
i=1;i<=100;i++) a[i]=i*i;
    while(cin>>n&&n){
        int
ok=0;
        for(int
i=2;a[i]<=n;i++){
            if(n%a[i]==0){
                cout<<"Yes"<<endl;
                ok=1;//标记是否找到满足条件的数
                break;
            }
        }
        if(!ok) cout<<"No"<<endl;
    }
    return
0;
}
 

题目三(jobdu1477:怪异的洗牌&&jobdu1479:移位与旋转)、  
http://ac.jobdu.com/problem.php?pid=1477

对一副扑克牌进行k个移位(shift)和翻转之后(filp),数组结果。

题目分析:

因为题目数据较小。没有必要去优化移位函数(shift)的时间复杂度,仅仅须要普通的移位函数就可以,对于翻转函数,进行折半交换就可以。



AC代码:

#include<iostream>
using
namespace
std;
int
n,k;
void
shift(
int a[],int
k){//向右循环k次
    while(k--){
        int
tmp=a[n-1];
        for(int
i=n-2;i>=0;i--){
            a[i+1]=a[i];
        }
        a[0]=tmp;
    }
}
void
filp(
int a[],int
n){//翻转数组的前n个数
    int
i,j,tmp;
    for(i=0,j=n-1;i<j;i++,j--){
        tmp=a[i];
        a[i]=a[j];
        a[j]=tmp;
    }
}
void
print(
int a[]){
    for(int
i=0;i<n;i++) cout<<a[i]<<" ";
    cout<<endl;
}
int
main()
{
    while(cin>>n>>k&&n){
        int
m,a[1005];
        for(int
i=0;i<n;i++) a[i]=i+1;
        //print(a);
        for(int
i=0;i<k;i++){
            cin>>m;
            shift(a,n-m);
            //print(a);
            filp(a,n/2);
        }
        print(a);
    }
    return
0;
}
 

题目四(jobdu1466:排列与二进制)、    http://ac.jobdu.com/problem.php?pid=1466

给定一个排列数,算出其二进制表示的后面有多少个连续的零。比方  p(10,5)=30240。

假设用二进制表示为p(10,5)=30240=( 111011000100000)b,也就是说。最后面有5个零。



题目分析:

对于一个数n,n包括(可以整除几个2)几个2,其二进制末尾就有几个0。比方 n=12

12/2=6(0)    6/2=3(0)   3/2=1(1);圆括号中面表示余数,12含有2个2,12的二进制是(1100)。尾部有2个0.



AC代码:

/**
 *一个数包括几个2,其二进制末尾就有几个0
 *比如12=(1100) 12/2=6; 6/2=3,有两个2
 */
#include<iostream>
using
namespace
std;
int
main()
{
    int
n,m;
    while(cin>>n>>m&&n){
        int
cnt=0;
        for(int
i=n;i>=n-m+1;i--){
            int
k=i;
            while(k%2==0){
                cnt++;
                k/=2;
            }
        }
        cout<<cnt<<endl;
    }
    return
0;
}

九度oj题目&amp;吉大考研10年机试题全解的更多相关文章

  1. 九度oj题目&amp;吉大考研11年机试题全解

    九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码).    http://ac.jobdu.com/problem.php?pid=11 ...

  2. 九度oj 题目1190:大整数排序

    题目1190:大整数排序 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:4142 解决:1867 题目描述: 对N个长度最长可达到1000的数进行排序. 输入: 输入第一行为一个整数N,( ...

  3. 九度oj 题目1125:大整数的因子

    题目描述: 已知正整数k满足2<=k<=9,现给出长度最大为30位的十进制非负整数c,求所有能整除c的k. 输入: 若干个非负整数c,c的位数<=30每行一个c,当c=-1时中止 ( ...

  4. 九度oj 题目1262:Sequence Construction puzzles(I)_构造全递增序列

    题目描述: 给定一个整数序列,请问如何去掉最少的元素使得原序列变成一个全递增的序列. 输入: 输入的第一行包括一个整数N(1<=N<=10000). 接下来的一行是N个满足题目描述条件的整 ...

  5. hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人

    钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  6. 九度OJ 题目1384:二维数组中的查找

    /********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...

  7. 九度oj 题目1007:奥运排序问题

    九度oj 题目1007:奥运排序问题   恢复 题目描述: 按要求,给国家进行排名. 输入:                        有多组数据. 第一行给出国家数N,要求排名的国家数M,国家号 ...

  8. 九度oj 题目1087:约数的个数

    题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...

  9. 九度OJ题目1105:字符串的反码

    tips:scanf,cin输入字符串遇到空格就停止,所以想输入一行字符并保留最后的"\0"还是用gets()函数比较好,九度OJ真操蛋,true?没有这个关键字,还是用1吧,还是 ...

随机推荐

  1. python-day3-内置函数与字符字节之间的转换

    #三元运算 1 if True else 0 >>>1 1 if False else 0 >>>0 #内置函数lambda def f1(a1): return ...

  2. python 学习分享-函数篇2

    递归 自己玩自己的函数: 1. 必须有一个明确的结束条件 2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减少 3. 递归效率不高,递归层次过多会导致栈溢出 递归例子和二分查找都放在里面了 ...

  3. PHP 获取客户端用户 IP 地址

    一般情况下可以使用以下代码获取到用户 IP 地址 echo 'User IP - '.$_SERVER['REMOTE_ADDR']; // 服务器在局域网的话,那么显示的则是内网IP .// 如果服 ...

  4. Leetcode 654.最大二叉树

    最大二叉树 给定一个不含重复元素的整数数组.一个以此数组构建的最大二叉树定义如下: 二叉树的根是数组中的最大元素. 左子树是通过数组中最大值左边部分构造出的最大二叉树. 右子树是通过数组中最大值右边部 ...

  5. python3.x与python2.x的区别(转)

    转自:http://www.cnblogs.com/codingmylife/archive/2010/06/06/1752807.html 1.性能 Py3.0运行 pystone benchmar ...

  6. 使用jsp读取TXT格式文件

    <%@page import="java.io.BufferedReader"%> <%@page import="java.io.FileReader ...

  7. CSS查缺补漏篇

    前面的话:关于CSS,之前我已经做过一些基础的知识点介绍.CSS主要是用来给页面设置样式的,一般说来,在一个网站中,CSS应该独立封装在一个单独的.css外部文件中.样式的设置总体来说是不难的,但是需 ...

  8. BZOJ 1010: [HNOI2008]玩具装箱toy(DP+斜率优化)

    [HNOI2008]玩具装箱toy Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊 ...

  9. 删除ARCSDE表空间和用户后,新建时出现error -1:O的解决办法

    对于刚开始使用arcsde的用户,可能会出现各种问题,慢慢来就会找到解决办法 当我们删除用户和表空间时,在服务器本地还保留这sde.dbf文件(删除时选择了删除本地文件,不知道为什么), 我们可以换一 ...

  10. mysql再次安装问题

    安装过一次mysql的电脑,想再安装或更换其它版本的mysql.在重新安装的最后一步,总会出现这样的问题. 网上说法也很多,什么删除注册表了等等.这都是狗屁. 真正的做法是找到C盘下的隐藏文件夹Pro ...