7-24 刮刮彩票
每次游戏玩家会拿到一张彩票,上面会有 9 个数字,分别为数字 1 到数字 9,数字各不重复,并以 3×3 的“九宫格”形式排布在彩票上。
在游戏开始时能看见一个位置上的数字,其他位置上的数字均不可见。你可以选择三个位置的数字刮开,这样玩家就能看见四个位置上的数字了。最后玩家再从 3 横、3 竖、2 斜共 8 个方向中挑选一个方向,方向上三个数字的和可根据下列表格进行兑奖,获得对应数额的金币。
#include "stdio.h"
int projectA(int *ch);
int main()
{
int a[3][3],x,y;
for(int i=0,k;i<3;i++)
for(int j=0;j<3;j++)
{
scanf("%d",&k);
if(k) a[i][j]=k;
else a[i][j]=k,x=i,y=j;//x,y记录初始数字位置。
}
a[x][y]=projectA(a);//将初位置的正确值赋入。
for(int i=0;i<3;i++)
{
scanf("%d %d",&x,&y);
printf("%d\n",a[x-1][y-1]);
}
int n,sum=0,b[19]={10000,36,720,360,80,252,108,72,54,180,72,180,119,36,306,1080,144,1800,3600};
scanf("%d",&n);
if(n>=1&&n<=3) sum=a[n-1][0]+a[n-1][1]+a[n-1][2];//计算数字和。
else if(n>=4&&n<=6) sum=a[0][n-4]+a[1][n-4]+a[2][n-4];
else if(n==7) sum=a[0][0]+a[1][1]+a[2][2];
else if(n==8) sum=a[2][0]+a[1][1]+a[0][2];
printf("%d",b[sum-6]);
return 0;
}
int projectA(int *ch)
{
for(int k=1,i;k<=9;k++)
{
for(i=0;i<9;i++)
if(k==*(ch+i)) break;//k未在数组中,证明k为初始值。
if(i==9) return k;
}
return 0;
}
7-6 数列求和-加强版
给定某数字A(1≤A≤9)以及非负整数N(0≤N≤100000),求数列之和S=A+AA+AAA+⋯+AA⋯A(N个A)。例如A=1, N=3时,S=1+11+111=123。
输入格式:
输入数字A与非负整数N。
输出格式:
输出其N项数列之和S的值。
输入样例:
1 3
输出样例:
123
#include "stdio.h"
int main()
{
int m,n,i,a,sum=0;
char ch[100002];
scanf("%d %d",&m,&n);
if(n==0||m==0) {printf("0");return 0;}
for(i=0;n>0;n--)
{
a=m*n+sum;
ch[i++]=a%10+48;
sum=a/10;
}
if(sum) printf("%d",sum);//最高位是一个大于一位数的数。
for(int j=i-1;j>=0;j--)
printf("%c",ch[j]);
return 0;
}