题目要求:
彩票的号码有 6 位数字,若一张彩票的前 3 位上的数之和等于后 3 位上的数之和,则称这张彩票是幸运的。本题就请你判断给定的彩票是不是幸运的。
输入格式:
输入在第一行中给出一个正整数 N(≤ 100)。随后 N 行,每行给出一张彩票的 6 位数字。
输出格式:
对每张彩票,如果它是幸运的,就在一行中输出 You are lucky!
;否则输出 Wish you good luck.
。
输入样例:
2 233008 123456
输出样例:
You are lucky! Wish you good luck.
思路:
1.循环输入n个6位数的数字
2.将这个6位数字前三位和后三位分别取出来放到俩个变量中
3.再次分别将前三位和后三位的每一位取出来分别放到一个求和变量中
4.判断俩个求和变量是否相等,对应输出不同结果,最终将俩个求和变量归零,进入下一个循环
代码:
#include <bits/stdc++.h> using namespace std; int main() { int n; cin >> n; int x; int x1,x2; int sum1 = 0,sum2 = 0; for(int i = 0; i < n; i ++) { cin >> x; x1 = x % 1000; x2 = x / 1000; int m = 3; while(m --) { sum1 += x1 % 10; x1 /= 10; sum2 += x2 % 10; x2 /= 10; } if(sum1 == sum2) cout << "You are lucky!" << endl; else cout << "Wish you good luck." << endl; sum1 = sum2 = 0; } }
测试结果: