求和
描述:
求sn=a+aa+aaa+…aa…a的值(最后一个数中a的个数为n),期中a是一个1~9的数字。
例如:2+22+222+2222+22222(此实a=2 n=5)
输入:
一行,包括两个整数,第一个为a,第二个为n(1<=a,n<=9),以空格分隔
输出:
一行,Sn的值。
#include<iostream>
using namespace std;
int sum(int a,int n);
int main()
{
int a,n;
cin>>a>>n;
cout<<sum(a,n)<<endl;
return 0;
}
int sum(int a,int n)
{
int y=0;
int sum=0;
for(int i=1;i<=n;i++)
{
y +=a;
sum +=y;
a*=10;
}
return sum;
}
求最大公约数
描述:
给定两个正整数,求他们最大公约数
输入:
有多组数据,每行为两个整数,且不超过int可以表示的范围
输出:
行对应输入出的最大公约数
#include<iostream>
using namespace std;
int gys(int a,int b);
int main()
{
int a,b;
while(cin>>a>>b)
{
cout<<gys(a,b)<<endl;
}
return 0;
}
int gys(int a,int b)
{
int r=a%b;
while(r)
{
a=b;
b=r;
r=a%b;
}
return b;
}
输出n天后的日期
描述:
设计一个程序,输入年月日(2010 10 28),输出n天后的日期。
输入:输入4个整数,分别是年、月、日和天。
输出:输出一行,为n天后的日期,以yyyy-mm-dd的格式输出
提示:要考虑全面,闰年问题,年末问题,月末问题。
#include<iostream>
#include<cstdio>
using namespace std;
bool isrun(int y);
int days(int y,int m);
int main()
{
int year,month,day,n;
cin>>year>>month>>day>>n;
while(n--)
{
if(month==12 && day==31)
{
year++;
month=1;
day=1;
}
else if(days(year,month)==day)
{
month++;
day=1;
}
else day++;
}
printf("%4d-%02d-%02d",year,month,day);
return 0;
}
bool isrun(int y)
{
if(y%4==0 && y%100!=0 || y%400==0)
return true;
else return false;
}
int days(int y,int m)
{
if(m==2 && isrun(y)) return 29;
else if(m==2) return 28;
else if(m==4 || m==6 || m==9 || m==11) return 30;
else return 31;
}