zoukankan      html  css  js  c++  java
  • 数学问题

     

    A + B分数: 1.8

    时间限制:1 秒
    内存限制:32 兆
    特殊判题: 否
    提交:171
    解决: 85

    标签

    • A+B
    • 字符串与数字对应
    • 字符串处理

    题目描述

    读入两个小于100的正整数A和B,计算A+B.
    需要注意的是:A和B的每一位数字由对应的英文单词给出.

    输入格式

    测试输入包含若干测试用例,每个测试用例占一行,格式为"A + B =",相邻两字符串有一个空格间隔.当A和B同时为0时输入结束,相应的结果不要输出.

    输出

    对每个测试用例输出1行,即A+B的值.

    样例输入

    one + two =
    three four + five six =
    zero seven + eight nine =
    zero + zero =

    样例输出

    3
    90
    96

    提示[+]

    *** 提示已隐藏,点击上方 [+] 可显示 ***

    分类

    • 浙江大学研究生复试上机真题
    •  
    •  
    •  
    • 这题天勤书上 “=”前面和“+”两边是没有空格的,但是
    • 原题是有的== 害我调试的半天   坑爹!!
    •  1 #include<iostream>
       2 #include<string>
       3 using namespace std;
       4  
       5 int zhuan(string s)
       6 {
       7    if(s=="zero") return 0;
       8    if(s=="one") return 1;
       9    if(s=="two") return 2;
      10    if(s=="three") return 3;
      11    if(s=="four") return 4;
      12    if(s=="five") return 5;
      13    if(s=="six") return 6;
      14    if(s=="seven") return 7;
      15    if(s=="eight") return 8;
      16    if(s=="nine") return 9;
      17 }
      18 int main()
      19 {
      20 string s;
      21 while(cin>>s)
      22 {
      23 int n=0;
      24 int n1=0;int n2=0;
      25 string ss[6];
      26 ss[n]=s;
      27 n++;
      28       while(cin>>s)
      29   {
      30    ss[n]=s;
      31    if(ss[n]=="=") break;
      32    n++;
      33   }
      34       if(ss[0]=="zero"&&ss[2]=="zero") break;
      35   int i=0;
      36   while(ss[i]!="+")
      37   {
      38     n1=n1*10+zhuan(ss[i]);
      39 i++;
      40   }
      41   i++;
      42    while(ss[i]!="=")
      43   {
      44     n2=n2*10+zhuan(ss[i]);
      45 i++;
      46   }
      47    cout<<n1+n2<<endl;
      48 }
      49  return 0;
      50 }
    •  












    Fibonacci分数: 1

    时间限制:1 秒
    内存限制:32 兆
    特殊判题: 否
    提交:87
    解决: 46

    标签

    • 斐波那契数列

    题目描述

    The Fibonacci Numbers{0,1,1,2,3,5,8,13,21,34,55...} are defined by the recurrence: 
    F0=0 F1=1 Fn=Fn-1+Fn-2,n>=2 
    Write a program to calculate the Fibonacci Numbers.

    输入格式

    Each case contains a number n and you are expected to calculate Fn.(0<=n<=30) 。

    输出

    For each case, print a number Fn on a separate line,which means the nth Fibonacci Number.

    样例输入

    1

    样例输出

    1

    提示[+]

    *** 提示已隐藏,点击上方 [+] 可显示 ***

    分类

    • 上海交通大学究生复试上机真题
    •  
    •  
    •  
    •  1 #include <iostream>
       2 using namespace std;
       3 int fi[30];
       4 int main()
       5 {
       6  fi[0]=0;
       7  fi[1]=1;
       8  for(int i=2;i<=30;i++)
       9  {
      10     fi[i]=fi[i-1]+fi[i-2];
      11  }
      12 int n;
      13  while(cin>>n)
      14  {
      15     cout<<fi[n]<<endl;
      16  }
      17     return 0;
      18 }
    •  









    对称平方数分数: 1.2

    时间限制:1 秒
    内存限制:32 兆
    特殊判题: 否
    提交:129
    解决: 67

    标签

    • 简单数学题
    • 对称平方数

    题目描述

    打印所有不超过256,其平方具有对称性质的数。如2,11就是这样的数,因为2*2=4,11*11=121。

    输入格式

    无任何输入数据

    输出

    输出具有题目要求的性质的数。如果输出数据不止一组,各组数据之间以回车隔开。

    样例输入

    样例输出

    提示[+]

    *** 提示已隐藏,点击上方 [+] 可显示 ***

    分类

    • 清华大学研究生复试上机真题
    •  
    •  
    •  
    •  
    •  1 #include <iostream>
       2 #include <sstream>
       3 #include <string>
       4 #include <algorithm>
       5 using namespace std;
       6 int main()
       7 {
       8   
       9    for(int i=0;i<256;i++)
      10    {
      11    string s;
      12    stringstream ss;
      13    ss<<i*i;
      14    ss>>s;
      15    string s2=s;
      16    reverse(s.begin(),s.end());
      17    if(s2==s) cout<<i<<endl;
      18    }
      19    
      20     return 0;
      21 }
    •  


















    最大公约数分数: 1

    时间限制:1 秒
    内存限制:32 兆
    特殊判题: 否
    提交:79
    解决: 50

    标签

    • 简单数学题
    • 最大公约数

    题目描述

    输入两个正整数,求其最大公约数。

    输入格式

    测试数据有多组,每组输入两个正整数。

    输出

    对于每组输入,请输出其最大公约数。

    样例输入

    49 14

    样例输出

    7

    提示[+]

    *** 提示已隐藏,点击上方 [+] 可显示 ***

    分类

    • 哈尔滨工业大学究生复试上机真题
    •  
    •  
    •  1 #include <iostream>
       2 #include <algorithm>
       3 using namespace std;
       4 int maxyue(int m,int n)
       5 {
       6  
       7    int temp=n;
       8    n=m%n;
       9    m=temp;
      10    if(n==0) return m;
      11    else return maxyue(m,n);
      12 }
      13 int main()
      14 {
      15    int n1,n2,m,n;
      16    while(cin>>n1)
      17    {
      18     cin>>n2;
      19     if(n1>n2) 
      20 {
      21   m=n1;n=n2;
      22 }
      23 else
      24 {
      25  m=n2;n=n1;
      26 }
      27    int yue=maxyue(m,n);
      28 cout<<yue<<endl;
      29    }
      30     return 0;
      31 }
    •  















    完数分数: 1.5

    时间限制:1 秒
    内存限制:32 兆
    特殊判题: 否
    提交:173
    解决: 60

    标签

    • 简单数学题
    • 分解因子
    • 完数

    题目描述

        求1-n内的完数,所谓的完数是这样的数,它的所有因子相加等于它自身,比如6有3个因子1,2,3,1+2+3=6,那么6是完数。即完数是等于其所有因子相加和的数。

    输入格式

        测试数据有多组,输入n,n数据范围不大。

    输出

        对于每组输入,请输出1-n内所有的完数。如有案例输出有多个数字,用空格隔开,输出最后不要有多余的空格。

    样例输入

    6

    样例输出

    6

    提示[+]

    *** 提示已隐藏,点击上方 [+] 可显示 ***

    分类

    • 哈尔滨工业大学究生复试上机真题
    •  
    •  
    •  1 #include <iostream>
       2 #include <math.h>
       3 using namespace std;
       4 bool IsPerfect(int n)
       5 {
       6    int len=(int)sqrt((double)n);
       7    int sum=1;//当n>1时,1是真因子,n不是
       8    for(int i=2;i<=len;i++)
       9    {
      10      if(n%i==0) sum+=i+n/i;//加上自己 和 对应的真因子
      11    }
      12    //若存在整数x,n=x*x,则x多加了一次
      13    if(n==len*len)  sum-=len;//当n=1时,在这里已经排除
      14    bool temp;
      15    if(sum==n) temp=true;
      16    else temp=false;
      17    return temp;
      18 }
      19 int main()
      20 {
      21    int n;
      22    while(cin>>n)
      23    {
      24      int i;
      25 for( i=1;i<=n;i++)
      26 if(IsPerfect(i))
      27 {
      28   cout<<i;break;
      29 }
      30 for(int j=i+1;j<=n;j++)
      31         if(IsPerfect(j))
      32 {
      33   cout<<" "<<j;
      34 }
      35    cout<<endl;
      36    }
      37     return 0;
      38 }
    •  











    素数判定分数: 1

    时间限制:1 秒
    内存限制:32 兆
    特殊判题: 否
    提交:167
    解决: 76

    标签

    • 素数判定

    题目描述

    给定一个数n,要求判断其是否为素数(0,1,负数都是非素数)。

    输入格式

    测试数据有多组,每组输入一个数n。

    输出

    对于每组输入,若是素数则输出yes,否则输入no。

    样例输入

    13

    样例输出

    yes

    提示[+]

    *** 提示已隐藏,点击上方 [+] 可显示 ***

    分类

    • 哈尔滨工业大学究生复试上机真题
    •  
    •  
    •  1 #include <iostream>
       2 using namespace std;
       3 int main()
       4 {
       5    int n;
       6    while(cin>>n)
       7    {
       8  bool su=1;
       9  for(int i=2;i<n;i++)
      10  {
      11    if(n%i==0) 
      12    {
      13       su=0;
      14   break;
      15    }
      16  }
      17  if(su&&n>1) cout<<"yes"<<endl;
      18  else cout<<"no"<<endl;
      19    }
      20     return 0;
      21 }
    •  












    N的阶乘分数: 2.5

    时间限制:1 秒
    内存限制:32 兆
    特殊判题: 否
    提交:91
    解决: 27

    标签

    • 数学题

    题目描述

    输入一个正整数N,输出N的阶乘。

    输入格式

    正整数N(0<=N<=1000)

    输出

    输入可能包括多组数据,对于每一组输入数据,输出N的阶乘

    样例输入

    0
    4
    7

    样例输出

    1
    24
    5040

    提示[+]

    *** 提示已隐藏,点击上方 [+] 可显示 ***

    分类

    • 清华大学研究生复试上机真题
    •  
    •  
    •  
    •  
    • 这题目有点小纠结
    •  
    •  
    • 自己写的大整数乘法:
    •  
    •  1 #include<iostream>
       2 #include<string>
       3 using namespace std;
       4 typedef struct {
       5 int num[1001];
       6 int length;
       7 }BigInt;
       8 //大数相加
       9 BigInt add(BigInt lon,BigInt sho)
      10 {
      11     BigInt temp;
      12 for(int i=0;i<sho.length;i++)
      13 {
      14 temp.num[i]=lon.num[i]+sho.num[i];
      15 }
      16 for(int i=sho.length;i<lon.length;i++)
      17 {
      18 temp.num[i]=lon.num[i];
      19 }
      20         for(int i=0;i<lon.length-1;i++)
      21 {
      22 if(temp.num[i]>9) 
      23 {
      24 temp.num[i+1]++;
      25 temp.num[i]=temp.num[i]-10;
      26 }
      27 }
      28 if(temp.num[lon.length-1]>9) 
      29 {
      30 temp.num[lon.length]=1;
      31 temp.num[lon.length-1]=temp.num[lon.length-1]-10;
      32 temp.length=lon.length+1;
      33 }
      34 else
      35            temp.length=lon.length;
      36 return temp;
      37 }
      38 //大数乘小整数
      39 BigInt mul(BigInt big,int a)
      40 {
      41    BigInt temp=big;
      42    for(int i=0;i<a-1;i++)
      43    temp=add(temp,big);
      44    return temp;
      45 }
      46 int main()
      47 {
      48       int n;
      49 while(cin>>n)
      50 {
      51   BigInt a;
      52   a.length=1;
      53   a.num[0]=1;
      54  
      55   for(int i=n;i>=1;i--)
      56   {
      57      a=mul(a,i);
      58   }
      59    for(int i=a.length-1;i>=0;i--)
      60   {
      61   cout<<a.num[i];
      62   }
      63    cout<<endl;
      64 }
      65 return 0;
      66 }
    •  
    • 果断超时了
    • 天勤书上面的代码也是超时的==}} 
      1 #include<iostream>
      2 
      3 #include<string>
      4 
      5 using namespace std;
      6 
      7  
      8 
      9 typedef struct {
     10 
     11 int num[1001];
     12 
     13 int length;
     14 
     15 }BigInt;
     16 
     17  
     18 
     19 //大数相乘
     20 
     21 BigInt mul(BigInt lon,BigInt sho)
     22 
     23 {
     24 
     25    BigInt temp;
     26 
     27 temp.length=0;
     28 
     29 for(int m=0;m<sho.length+lon.length+1;m++)
     30 
     31     temp.num[m]=0;//n位数*m位数 所得到的最大位数为n+m;初始化各各位置
     32 
     33  
     34 
     35 for(int i=0;i<sho.length;i++)
     36 
     37 for(int j=0;j<lon.length;j++)
     38 
     39 temp.num[i+j]=temp.num[i+j]+lon.num[j]*sho.num[i];
     40 
     41  
     42 
     43 //调整进位
     44 
     45  
     46 
     47 while(temp.length<lon.length+sho.length-1||temp.num[temp.length]!=0)
     48 
     49 {
     50 
     51 temp.num[temp.length+1]=temp.num[temp.length+1]+temp.num[temp.length]/10;//如果最后一位没进位,则m+n位为0
     52 
     53 temp.num[temp.length]=temp.num[temp.length]%10;
     54 
     55 temp.length++;
     56 
     57 }
     58 
     59  
     60 
     61 return temp;
     62 
     63 }
     64 
     65  
     66 
     67 BigInt zhuan(int n)//将int转成大数,倒着存放
     68 
     69 {
     70 
     71    BigInt temp;
     72 
     73    temp.length=0;
     74 
     75    while(n)
     76 
     77    {
     78 
     79   temp.num[temp.length]=n%10;
     80 
     81   n=n/10;
     82 
     83   temp.length++;
     84 
     85    }
     86 
     87     
     88 
     89    return temp;
     90 
     91 }
     92 
     93  
     94 
     95 int main()
     96 
     97 {
     98 
     99 int n; 
    100 
    101 while(cin>>n)
    102 
    103 {
    104 
    105  BigInt a=zhuan(1);
    106 
    107  
    108 
    109  for(int i=2;i<=n;i++)
    110 
    111  {
    112 
    113     a=mul(a,zhuan(i));
    114 
    115  }
    116 
    117   for(int k=a.length-1;k>=0;k--)
    118 
    119  {
    120 
    121  cout<<a.num[k];
    122 
    123  }
    124 
    125   cout<<endl;
    126 
    127 }
    128 
    129 return 0;
    130 
    131 }

    最后,在王道论坛上看到牛人代码:

     1 #include <iostream>
     2 
     3 using namespace std;
     4 
     5 int main()
     6 
     7 {
     8 
     9     int n;
    10 
    11     while (cin>>n)
    12 
    13     {
    14 
    15         int i, j;
    16 
    17 int res[10010]={0};
    18 
    19         res[0] = 1;
    20 
    21         res[1] = 1;
    22 
    23         for (i = 2; i <= n; i++)
    24 
    25         {
    26 
    27             for (j = 1; j <= res[0]; j++)
    28 
    29                 res[j] = res[j] * i;
    30 
    31             
    32 
    33             for (j = 1; j <= res[0]; j++)
    34 
    35             {
    36 
    37                 if (res[j] >= 10)
    38 
    39                 {
    40 
    41                     res[j+1] += res[j] / 10;
    42 
    43                     res[j] %= 10;
    44 
    45                     if (j == res[0])
    46 
    47                         res[0]++;
    48 
    49                 }
    50 
    51             }
    52 
    53         }
    54 
    55         for (i = res[0]; i >= 1; i--)
    56 
    57            cout<<res[i];
    58 
    59         cout<<endl;
    60 
    61     }
    62 
    63     return 0;
    64 
    65 } 








    数字求和分数: 1

    时间限制:1 秒
    内存限制:32 兆
    特殊判题: 否
    提交:87
    解决: 55

    标签

    • 简单模拟计算

    题目描述

    给定一个正整数a,以及另外的5个正整数,问题是:这5个整数中,小于a的整数的和是多少?

    输入格式

    输入一行,只包括6个小于100的正整数,其中第一个正整数就是a。

    输出

    可能有多组测试数据,对于每组数据,输出一行,给出一个正整数,是5个数中小于a的数的和。

    样例输入

    10 1 2 3 4 11

    样例输出

    10

    提示[+]

    *** 提示已隐藏,点击上方 [+] 可显示 ***

    分类

    • 北京大学研究生复试上机真题
    •  
    •  1 #include<iostream>
       2 using namespace std;
       3 int main()
       4 {
       5 int n[5];
       6    int a;
       7    while(cin>>a)
       8    {
       9       for(int i=0;i<5;i++)
      10   cin>>n[i];
      11   int sum=0;
      12    for(int i=0;i<5;i++)
      13    if(n[i]<a) sum=sum+n[i];
      14    cout<<sum<<endl;
      15    }
      16 return 0;
      17 }
    •  









    A+B分数: 2

    时间限制:1 秒
    内存限制:32 兆
    特殊判题: 否
    提交:92
    解决: 55

    标签

    • 字符串处理

    题目描述

    给定两个整数A和B,其表示形式是:从个位开始,每三位数用逗号","隔开。
    现在请计算A+B的结果,并以正常形式输出。

    输入格式

    输入包含多组数据数据,每组数据占一行,由两个整数A和B组成(-10^9 < A,B < 10^9)。

    输出

    请计算A+B的结果,并以正常形式输出,每组数据占一行。

    样例输入

    -234,567,890 123,456,789
    1,234 2,345,678

    样例输出

    -111111101
    2346912

    提示[+]

    *** 提示已隐藏,点击上方 [+] 可显示 ***

    分类

    • 浙江大学研究生复试上机真题
    •  
    •  
    •  
    •  
    •  1 #include <iostream>
       2 #include <algorithm>
       3 #include<string>
       4 #include<sstream>
       5 using namespace std;
       6 string clear(string s)
       7 {
       8        for(int i=0;i<s.length();i++)
       9    {
      10    if(s[i]==',')  s=s.substr(0,i)+s.substr(i+1,s.length()-i); 
      11    }
      12    return s;
      13 }
      14 int main()
      15 {
      16 string s1,s2;
      17 while(cin>>s1)
      18 {
      19    cin>>s2;
      20    s1=clear(s1);s2=clear(s2);
      21    stringstream ss1,ss2;
      22    long n1,n2,sum;
      23    ss1<<s1;
      24    ss1>>n1;
      25    ss2<<s2;
      26    ss2>>n2;
      27    sum=n1+n2;
      28    cout<<sum<<endl;
      29 }
      30   return 0;
      31 }
    •  










    数字之和分数: 1.5

    时间限制:1 秒
    内存限制:32 兆
    特殊判题: 否
    提交:84
    解决: 54

    标签

    • 简单计算

    题目描述

    对于给定的正整数 n,计算其十进制形式下所有位置数字之和,并计算其平方的各位数字之和。

    输入格式

    每行输入数据包括一个正整数n(0<n<40000),如果n=0 表示输入结束,并不用计算。

    输出

    对于每个输入数据,计算其各位数字之和,以及其平方值的数字之和,输出在一行中,之间用一个空格分隔,但行末不要有空格。

    样例输入

    4
    12
    97
    39999
    0

    样例输出

    4 7
    3 9
    16 22
    39 36

    提示[+]

    *** 提示已隐藏,点击上方 [+] 可显示 ***

    分类

    • 吉林大学究生复试上机真题
    •  
    •  
    •  1 #include <iostream>
       2 #include <algorithm>
       3 #include<string>
       4 #include<sstream>
       5 using namespace std;
       6 int ch[128]={0};
       7 int all(string s)
       8 {
       9    int sum=0;
      10    for(int i=0;i<s.length();i++)
      11 {
      12    sum=sum+ch[s[i]];
      13 }
      14    return sum;
      15 }
      16 int main()
      17 {
      18 ch['0']=0;ch['1']=1;ch['2']=2;
      19 ch['3']=3;ch['4']=4;ch['5']=5;
      20 ch['6']=6;ch['7']=7;ch['8']=8;ch['9']=9;
      21 string s;
      22 while(getline(cin,s))
      23 {
      24     if(s=="0") break;
      25 int sum=all(s);
      26 cout<<sum<<" ";
      27 int temp;
      28 stringstream ss1,ss2;
      29 ss1<<s;
      30 ss1>>temp;
      31 temp=temp*temp;
      32 ss2<<temp;
      33 ss2>>s;
      34 sum=all(s);
      35 cout<<sum<<endl;
      36 }
      37   return 0;
      38 }
    •  
     








    求最大值分数: 1

    时间限制:1 秒
    内存限制:32 兆
    特殊判题: 否
    提交:243
    解决: 69

    标签

    • 求最大值

    题目描述

    输入10个数,要求输出其中的最大值。

    输入格式

    测试数据有多组,每组10个数。

    输出

    对于每组输入,请输出其最大值(有回车)。

    样例输入

    10 22 23 152 65 79 85 96 32 1

    样例输出

    max=152

    提示[+]

    *** 提示已隐藏,点击上方 [+] 可显示 ***

    分类

    • 哈尔滨工业大学究生复试上机真题
    •  
    •  
    •  
    •  1 #include <iostream>
       2 #include <algorithm>
       3 using namespace std;
       4 int main()
       5 {
       6 int a[10];
       7 while(cin>>a[0])
       8 {
       9     
      10    for(int i=1;i<10;i++)
      11    cin>>a[i];
      12    int m=a[0];
      13    for(int i=1;i<10;i++)
      14    m=max(a[i],m);
      15    cout<<"max="<<m<<endl;
      16 }
      17   return 0;
      18 }
  • 相关阅读:
    Python Semaphore
    Python 互斥锁
    Python 递归锁
    Python GIL锁
    Python 线程调用
    进程与线程
    Python paramiko模块
    Python SocketServer模块
    MonoDevelop with Visual Studio to Linux and Mac OSX maintaining a single code base for all platforms.
    mime大全收集
  • 原文地址:https://www.cnblogs.com/xiaoyesoso/p/4276304.html
Copyright © 2011-2022 走看看