1.未知个数数组中最大值
#include <iostream>
using namespace std;
int main ()
{
int a[100];//数组char定义
int i=0,sum,max=-10000;
for (i=0;;i++)//输入未知个数的数组
{
scanf("%d",&a[i]); //用cin会错
if (getchar()=='\n') break;
}
sum=i+1;
for (i=0;i<sum;i++)
{
if (a[i]>max)
max=a[i];
}
cout<<max;
}
2.密码破译
#include <iostream>
using namespace std;
int main ()
{
char a[100];
gets(a);//输入字符串 cin>>a(针对一个空格分隔出来的内容);gets(a)(中间可有空格,但空格也占用一个位置)
for (int i=0;a[i]!='\0';i++)//字符串以'\0'结尾
{
if (a[i]>='A'&&a[i]<='Z')
{
a[i]=(a[i]+4-'A')%26+'A';//后移4位,取余数,防止超出Z
}
if (a[i]>='a'&&a[i]<='z')
{
a[i]=(a[i]+4-'a')%26+'a';
}
}
puts(a); //输出字符串 cout<<a;
}
3.温度转换
#include<stdio.h>
int main()
{
double f,c;
scanf ("%lf",&f); //double--lf;float--f
c=5*(f-32)/9;
printf ("c=%0.2lf",c);//保留两位小数,格式
}
4.分段函数求值
#include <iostream>
using namespace std;
int main ()
{
int x,y;
cin>>x;
if (x<1) y=x;
else if (1<=x && x<10) y=2*x-1;//选择结构有3种;大小比较得单个写
else y=3*x-11;
cout<<y;
}
5.数字的处理与判断
(1)转为字符串处理
#include <iostream>
using namespace std;
#include <string.h>
int main ()
{
char a[100];
cin>>a;
int len=strlen(a);
cout<<len<<endl;//输出个数
for (int i=0;i<len;i++)//逐个输出
{
cout<<a[i]<<" ";
if (i==len-1) cout<<endl;
}
//cout<<endl;
for (int i=len-1;i>=0;i--)//逆序输出
{
cout<<a[i];
}
}
/*注意:
1.格式要求:空格 换行 (逻辑关系,在循环内还是外用)
2.当成字符串处理:要加头文件 <string.h> ;用char定义a[],而非int;输入用gets(),cin>> ,getchar();输出 puts(),cout<< ;strlen()函数使用
3.循环:I++ 还是I--
4.判断:== != >=
*/
(2)十进制取整求余处理
#include <iostream>
using namespace std;
#include <math.h>
int main ()
{
int x,xx,xxx,ws=1,a,b,i;
cin>>xx;
x=xx;
xxx=xx;
while(xx/10!=0)//位数 /10
{
ws++;
xx=xx/10;
}
cout<<ws<<endl;
for (i=ws;i>0;i--)//正序输出 /pow %pow
{
a=x/pow(10,i-1);
cout<<a<<" ";
int z=pow(10,i-1);
x=x%z;
//x=x%pow(10,i-1);
}
cout<<endl;
for (i=1;i<=ws;i++)//逆序输出 %10 /10
{
b=xxx%10;
cout<<b<<" ";
xxx=xxx/10;
//int y=pow(10,i);
//b=x%pow(10,i);
//xxx=xxx/pow(10,i);
}
cout<<endl;
}
/*注意:
1.需要多次对x进行操作时,要保留一个x的副本
2. 3种方法要记住
*/
6.最大公约数,最小公倍数(辗转相除法)
#include<iostream>
using namespace std;
int gys(int x,int y)//最大公约数
{
if (y==0) return x;
return gys(y,x%y);
}
int gbs(int x,int y)//最小公倍数 =x*y/最大公约数
{
return x*y/gys(x,y);
}
int main()
{
int x,y,a,b;
cin>>x>>y;
a=gys(x,y);
b=gbs(x,y);
cout<<a<<" "<<b;
}
/*
注意最大公约数和最小公倍数的求法
*/
7.2+22+222+2222...求和
#include <iostream>
using namespace std;
#include <math.h>
int main ()
{
int n,a=2,b=0,sum=0,i;
cin>>n;
for (i=0;i<n;i++)//双重累加
{
b+=a*pow(10,i);
sum+=b;
}
cout<<sum;
}
8.阶乘求和
#include <iostream>
using namespace std;
#include <math.h>
int main ()
{
int n,i;
long long sum=0,a=1;//用long long定义,不用int
cin>>n;
//因为这是阶乘求和,一般的int 类型可能就不够,因此我们利用long long int 类型(不用unsigned long 因为当n为20时,Sn =2561327494111820313)
for(i=1;i<=n;i++)
{
a=a*i;//阶乘
sum+=a;//求和
}
cout<<sum;
}
9.求以下三数的和,保留2位小数 1~a之和 1~b的平方和 1~c的倒数和
#include <iostream>
using namespace std;
#include <math.h>
int main ()
{
double a=0,b=0,c=0,s=0,u=0,m=0,i,sum;
cin>>a>>b>>c;
for (i=1;i<=a;i++)
{
//a+=1;错了
s+=i;
}
for (i=1;i<=b;i++)
{
//b+=1;
s+=i*i;
}
for(i=1;i<=c;i++)
{
//c+=1;
s+=1.0/i;//double类型 1.0/
}
sum=s+u+m;
printf("%0.2lf",sum); //保留两位小数
}
查漏补缺:
1.数组 和 字符串的定义,类型,输入,求长度;
2.各种类型的输入(cin scanf getchar gets),输出(cout printf puts)等的使用方法及情况;