循环结构程序设计

1.位数
输入一个不超过10^9的正整数,输出它的位数.例如12735的位数是5.请不要使用任何数学函数,只用四则运算和循环语句实现.
#include<iostream>
using namespace std;
int main()
{
 float maxmal= 1000000000;
int a=234234,i=0,b=1,t=1;
while(b>=1){
        b=a/t;
        t=t*10;
        if(b>=1){
        i++;
        }
    }
cout<<i<<endl;
return 0;
}
 
2.水仙花数
输出(100-999)中的所有水仙花数.若3位数abc满足abc=a^3+b^3+c^3,则称其为水仙花数.例如153=1^3+5^3+3^3,所以153是水仙花数.
 
#include<iostream>
using namespace std;
int main()
{
    int a ,b,c,i;
for(i=100;i<1000;i++){
   a = i/100;
   b = i/10%10;
   c = i%10;
   if(i==a*a*a+b*b*b+c*c*c)
    {
        cout<<i<<endl;
    }
}
return 0;
}
 
3.韩信点兵
相信韩信才智过人,从不直接清点自己军队的人数,只要让士兵先后以三人一排、五人一排、七人一排地变换队形,而他每次只要掠一眼队伍的排尾就知道总人数了.输入3个非负整数a,b,c,表示每种队形排尾的人数(a<3,b<5,c<7),输出总人数的最小值(或报告无解).已知总人数不小于10,不超过1000.
    样例输入: 2 1 6
    样例输出:41
    样例输入:2 1 3
    样例输出:No answer. 
    已知总人数不小于10,不超过100.
 
 
#include<iostream>
using namespace std;
int main()
{
    int a,b,c,m,n,l,temp,i=1,templi;
    bool flag=false;
    cin>>a>>b>>c;
    for(;i<=14;i++){
        temp=7*i+c;
            if((temp-b)%5==0&&(temp-a)%3==0&&temp<=100&&temp>=10){
            flag=true;
            templi=temp;
        }
    }
    if(flag){
        cout<<"最少人数为:"<<templi<<endl;
        }else{
        cout<<"No Answer"<<endl;
        }
 
        return 0;
}
 
 
4.倒三角形
输入正整数n<=20,输出一个n层的倒三角形.
#include<iostream>
using namespace std;
int main()
{
    int i =0;
  cin>>i;
    string s="";
    string backs="";
    int k=i;
    for(;i>=0;i--){
        for(int j=0;j<2*i-1;j++)
             s+="#";
    for(int h=0;h<k-i;h++){
          backs+=" ";
    }
    cout<<backs+s<<endl;
    s="";
    backs="";
 
}
return 0;
}
 
5.统计
输入一个正整数n,然后读取n个正整数a1,a2,...,an,最后再读一个正整数m.统计a1,a2,...,an中有多少个整数的值小于m.
#include<iostream>
#include<vector>
using namespace std;
 
int main()
{
    cout<<"输入的数字个数为"<<endl;
    int n,temp,m,k=0;
    cin>>n;
    vector<int> num;
    for(vector<int>::size_type index=0;index!=n;++index){
        cout<<"当前输入第"<<index+1<<"个"<<endl;
        cin>>temp;
        num.push_back(temp);
    }
    cout<<"再输入m的值"<<endl;
    cin>>m;
    for(vector<int>::iterator index=num.begin();index!=num.end();++index){
        if(*index<m){
            k++;
        }
    }
    cout<<"比m小的数有"<<k<<"个"<<endl;
    return 0;
}
 
6.调和级数
输入正整数n.输出H(n)=1+1/2+1/3+1/4+...+1/n的值,保留3位小数.例如n=3时答案为1.833.
#include<iostream>
#include<vector>
#include <iomanip>
using namespace std;
 
int main()
{
    int n;
    double sum=0;
    cin>>n;
    for(int i=1;i<=n;i++)
        {
            sum+=1.0/i;
        }
    cout<<fixed<<setprecision(3)<<sum<<endl;
    return 0;
}
 
7,近似计算
计算pi/4=1-1/3+1/5-1/7+...知道最后一项小于10^(-6)
 
#include<iostream>
#include<vector>
#include <iomanip>
using namespace std;
 
int main()
{
    int flag=1;
    int n =1;
    double sum=0.0;
    while(1.0/n>0.000001){
        sum+=flag*(1.0)/n;
        flag=(-1)*flag;
        n+=2;
    }
   // cout<<n<<endl;
    cout<<sum<<endl;
    cout<<3.1415/4<<endl;
 
return 0;
}
 
8.子序列的和
输入两个正整数n<m<10^6,输出  1/n^2+1/(n+1)^2+..+1/m^2,保留五位小数.例如n=2,m=4,答案是0.42361,n=65536,m=655360时答案是0.00001
 
 
#include<iostream>
#include<vector>
#include <iomanip>
using namespace std;
 
int main()
{
    int n,m;
    cin>>n>>m;
   long double  sum=0.0;
    for(int i = n;i<=m;++i)
        {
            sum+=1.0/i/i;
        }
    cout<<fixed<<setprecision(5)<<sum<<endl;
return 0;
}
 
9.分数化小数
输入正整数a,b,c,输出a/b的小数形式,精确到小数点后c位.a,b<=10^6,c<=100.例如a=1,b=6,c=4时应输出0.1667.
#include<iostream>
#include<vector>
#include <iomanip>
using namespace std;
 
int main()
{
double a,b,c;
double result;
cin>>a>>b>>c;
result=a/b;
cout<<fixed<<setprecision(c)<<result<<endl;
return 0;
}
 
10.排列
用1,2,3,...,9组成3个三位数abc,def和ghi,每个数字恰好使用一次,要求abc:def:ghi=1:2:3.输出所有解.提示:不必太动脑筋.
#include<iostream>
#include<vector>
#include <iomanip>
using namespace std;
void checkNum(int num[]);
int main()
{
    int beg,beg2,beg3,a,b,c,d,e,f,g,h,i;
    int num[9];
 
    for(beg =123;beg<=987;beg++)
        {
            beg2 = 2*beg;beg3=3*beg;
            if(beg3<=987){
                num[0]=beg/100;
                num[1]=beg/10%10;
                num[2]=beg%10;
                num[3]=beg2/100;
                num[4]=beg2/10%10;
                num[5]=beg2%10;
                num[6]=beg3/100;
                num[7]=beg3/10%10;
                num[8]=beg3%10;
                checkNum(num);
 
            }
        }
 
return 0;
}
 
 
void checkNum(int num[])
{
    int result[9]={0,0,0,0,0,0,0,0,0};
    bool flag=true;
  for(int i =0;i<9;i++){
    switch(num[i])
    {
        case 1:
        result[0]++;
        break;
        case 2:
        result[1]++;
        break;
        case 3:
        result[2]++;
        break;
        case 4:
        result[3]++;
        break;
        case 5:
        result[4]++;
        break;
        case 6:
        result[5]++;
        break;
        case 7:
        result[6]++;
        break;
        case 8:
        result[7]++;
        break;
        case 9:
        result[8]++;
        break;
        case 0:
        return;
    }
  }
  for(int i =0;i<=8;++i){
    if(result[i]>1)flag=false;
  }
  if(flag==true)
    {
        for(int i =0;i<=8;++i){
                if((i+1)%3==1){
                    cout<<"   ";
                }
        cout<<num[i];
        }
        cout<<endl;
    }
 
}
posted @ 2013-08-20 13:41  CrazyCode.  阅读(370)  评论(0编辑  收藏  举报