目录
1、大数加法
2、结束输入
3、qsort(快排)
4、c++控制小数位数
5、转换double
1、大数加法
题目:A+B problem Ⅱ(oj)
体会:当遇到纯数字题目时,也可以使用字符串来解题,特别是大数,long long范围过小,应选用字符串解决。
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
const int L=110;
string add(string A,string B);
string add(string A,string B)
{
string ans;
int a[L]={0},b[L]={0};
int lenA=A.size(),lenB=B.size();
for(int i=0;i<lenA;i++)
{
a[lenA-1-i]=A[i]-'0';
}
for(int i=0;i<lenB;i++)
{
b[lenB-1-i]=B[i]-'0';
}
int Max=lenA>lenB?lenA:lenB;
for(int i=0;i<Max;i++)
{
a[i]+=b[i];
a[i+1]+=a[i]/10;
a[i]%=10;
}
if(!a[Max])
Max--;
for(int i=Max;i>=0;i--)
ans+=a[i]+'0';
return ans;
}
int main()
{
int T;
string A,B,sum;
cin>>T;
for(int i=0;i<T;i++)
{
cin>>A>>B;
sum=add(A,B);
cout<<"Case "<<i+1<<":"<<endl
<<A<<" + "<<B<<" = "<<sum<<endl<<endl;
}
return 0;
}
2、结束输入
? ? ????while(cin>>n,n):表示输入一个数,当其为不为0时进行循环,为0时跳出循环。
????????while(scanf(“%d“,&a)!=EOF)? while(scanf(“%d“,&a)==1)? ?while(~scanf(“%d“,&a)):三者作用相同,当手动输入ctrl+z时跳出循环。
——主要用于有多种数据输入时,如下图。
3、qsort(快排)
qsort(char *a, int len=strlen(a), sizeof(a[]), int cmp);
功能:对数组进行排序?
使用时需要自己根据实际情况写cmp(比较)函数。
int cmp(const void *a, const void *b)//根据实际情况,不唯一
{
return *(char*)a<*(char*)b;
}
4、c++控制小数位数
需加上头文件#include<iomanip> cout<<fixed<<setprecision(2)<<a<<endl; fixed表示从小数点开始计数,若不加fixed,则表示有效数字的保留。 补充: cout<<setw(2)<<setfill('0')<<a<<endl;//输出两位数,不足部分补0
5、转换double
将3/2的结果变为double时,可乘1.0,即3.0/2。
~学习计算机的小白一枚,有错误欢迎指正呀,mua~
|