版权声明:本人菜鸟一只,如文章有错误或您有高见,请不吝赐教 https://blog.csdn.net/qq_41138935/article/details/83626538
任务一:数据插入
利用sort函数:
#include<cstdio>
#include<algorithm>
using namespace std;
int main(){
int b[15]={1,2,7,12,14,15,16,19,25,65,100};
const int t=11;
int v; //插入的数
scanf("%d",&v);
b[t]=v;
sort(b,b+(t+1));
for(int i=0;i<t+1;i++)
printf("%d\t",b[i]);
return 0;
}
#include<cstdio>
int main(){
int b[15]={1,2,7,12,14,15,16,19,25,65,100};
const int t=11;
int v; //插入的数
scanf("%d",&v);
for(int i=t-1;i>=0;i--){
if(v>=b[t-1]){ //最后一位
b[t]=v;
break;
}
if(b[i]<=v&&v<b[i+1]){ //中间
b[i+1]=v;
break;
}
else
b[i+1]=b[i];
}
if(v<=b[1]){ //最前
b[0]=v;
}
for(int i=0;i<t+1;i++)
printf("%d\t",b[i]);
return 0;
}
任务二:用户登陆验证
#include<cstdio>
#include<iostream>
#include<algorithm>
using namespace std;
#define QQ "123456"
#define PD "123"
int flag=3; //机会
int main(){
string qq; //账号
string pd; //密码
while(flag){
printf("%s","请输入账号:");
cin>>qq;
printf("%s","请输入密码:");
cin>>pd;
if(qq==QQ&&pd==PD){
printf("恭喜!登陆成功。\n账号:%s\n密码:%s\n",QQ,PD);
break;
} else{
printf("登陆失败。剩余机会%d次\n",--flag);
}
}
if(!flag)
printf("\n登陆的机会已用完!");
return 0;
}
任务三:纸牌游戏
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int arr[53];
int main(){
memset(arr,1,sizeof(arr)); //arr全部元素赋值为1,代表正面朝上
for(int i=2;i<=52;i++){
for(int j=2;j<=52;j++){
if(j%i==0){
arr[j]=!arr[j];
}
}
}
for(int i=1;i<=52;i++){
if(arr[i])
printf("%d\t",i);
}
return 0;
}
任务四:矩阵运算
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int a[100]={0,1,0,-1,1,1,-3};
/*表示矩阵 1 0 -1
1 1 -3 */
int b[100]={0,0,3,1,2,3,1};
/*表示矩阵 0 3
1 2
3 1 */
//矩阵A 2*3 矩阵B 3*2
int sum[100];
int main(){
int n=2,m=3;
int k=1,i=1,s_t=1,j,aa,t;
while(k<=n){
memset(sum,0,sizeof(sum));
for(j=1;j<=m*n;i++,j+=n){
for(aa=0;aa<n;aa++)
sum[aa]+=a[i]*b[j+aa];
}
for(t=0;t<n;t++)
printf("%d ",sum[t]);
puts("");
k++;
}
return 0;
}
任务五:大整数加法运算
参考:https://blog.csdn.net/qq_41138935/article/details/83759244
c++ 大整数类模板
#include<iostream>
#include<vector>
#include<cstring>
using namespace std;
struct BigInteger{
static const int BASE=100000000;
static const int WIDTH=8;
vector<int> s;
BigInteger(long long num=0){*this=num;} //构造函数
BigInteger operator = (long long num){ //赋值运算符
s.clear();
do{
s.push_back(num%BASE);
num/=BASE;
}while(num>0);
return *this;
}
BigInteger operator =(const string& str){ //赋值运算符
s.clear();
int x,len=(str.length()-1)/WIDTH+1;
for(int i=0;i<len;i++){
int end=str.length()-i*WIDTH;
int start=max(0,end-WIDTH);
sscanf(str.substr(start,end-start).c_str(),"%d",&x);
s.push_back(x);
}
return *this;
}
BigInteger operator + (const BigInteger& b) const{
BigInteger c;
c.s.clear();
for(int i=0,g=0;;i++){
if(g==0&&i>=s.size()&&i>=b.s.size()) break;
int x=g;
if(i<s.size()) x+=s[i];
if(i<b.s.size()) x+=b.s[i];
c.s.push_back(x % BASE);
g=x/BASE;
}
return c;
}
BigInteger operator += (const BigInteger& b){
*this=*this+b;
return *this;
}
};
//输入与输出
ostream& operator << (ostream &out,const BigInteger& x){
out << x.s.back();
for(int i=x.s.size()-2;i>=0;i--){
char buf[20];
sprintf(buf,"%08d",x.s[i]);
for(int j=0;j<strlen(buf);j++) out << buf[j];
}
return out;
}
istream& operator >> (istream &in,BigInteger& x){
string s;
if(!(in>>s)) return in;
x=s;
return in;
}
int main(){
BigInteger a,b,sum;
cin>>a>>b;
cout<<a+b<<endl;
return 0;
}