在对银行账户等重要权限设置密码的时候,我们常常遇到这样的烦恼:如果为了好记用生日吧,容易被破解,不安全;如果设置不好记的密码,又担心自己也会忘记;如果写在纸上,担心纸张被别人发现或弄丢了...
这个程序的任务就是把一串拼音字母转换为6位数字(密码)。我们可以使用任何好记的拼音串(比如名字,王喜明,就写:wangximing)作为输入,程序输出6位数字。
变换的过程如下:
第一步. 把字符串6个一组折叠起来,比如wangximing则变为:
wangxi
ming
第二步. 把所有垂直在同一个位置的字符的ascii码值相加,得出6个数字,如上面的例子,则得出:
228 202 220 206 120 105
第三步. 再把每个数字“缩位”处理:就是把每个位的数字相加,得出的数字如果不是一位数字,就再缩位,直到变成一位数字为止。例如: 228 => 2+2+8=12 => 1+2=3
上面的数字缩位后变为:344836, 这就是程序最终的输出结果!
要求程序从标准输入接收数据,在标准输出上输出结果。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int shrinkValue(int sum)
{
int temp = sum;
while (temp >= 10)
{
int newSum = 0;
while (temp > 0)
{
newSum += temp % 10;
temp /= 10;
}
temp = newSum;
}
return temp;
}
int main()
{
int n;
scanf("%d", &n);
char strings[n][100];
for (int i = 0; i < n; i++)
{
scanf("%s", strings[i]);
}
for (int i = 0; i < n; i++)
{
int length = strlen(strings[i]);
int foldedLength = length / 6;
if (length % 6 != 0)
{
foldedLength++;
}
int sums[6] = { 0 };
for (int j = 0; j < foldedLength; j++)
{
for (int k = 0; k < 6 && j * 6 + k < length; k++)
{
sums[k] += strings[i][j * 6 + k];
}
}
for (int j = 0; j < 6; j++)
{
int shrunkValue = shrinkValue(sums[j]);
printf("%d", shrunkValue);
}
printf("\n");
}
return 0;
}
众所周知,实验室的小叶子长的很黑,但是,他自己却总是喜欢颠倒黑白,总喜欢把黑的说成白的(比如 他自己,O(∩_∩)O哈哈~)。这不,有一天,他又开始了他的颠倒之路了。他拿出了两个数,试图颠倒这两个数。规则如下:如果这两个数的反转的和等于两个数和的反转,例如: 12和34。12的反转是21,34的反转是43,21+43=64,而12+34=46,46的反转为64。两个经过反转的数相等,那么他就颠倒失败了,否则他就成功了!!
#include<stdio.h>
int fz(int a)
{
int nx = 0;
while (a > 0)
{
nx = nx * 10 + a % 10;
a /= 10;
}
return nx;
}
int main()
{
int n;
scanf("%d", &n);
while (n--)
{
int a, b;
scanf("%d %d", &a, &b);
if (fz(a) + fz(b) == fz(a + b))
printf("%d\n", a + b);
else
printf("小叶子颠倒成功\n");
}
return 0;
}
设有一数列,包含10个数,已按升序排好。现要求编一程序,它能够把从指定位置m开始的n个数按逆序重新排列并输出新的完整数列。
#include<stdio.h>
int main()
{
int m, n;
int arr[10];
char arr1[3], arr2[3];
for (int i = 0; i < 10; i++)
{
scanf("%d", &arr[i]);
}
getchar();
scanf("m:%d", &m);
getchar();
scanf("n:%d", &n);
for (int i = 0; i < m; i++)
{
printf("%d ", arr[i]);
}
for (int j = m + n-1; j >= m; j--)
{
printf("%d ", arr[j]);
}
for (int k = m + n; k < 10; k++)
{
printf("%d ", arr[k]);
}
return 0;
}
最近眺爷无聊的玩起了数格点的游戏,现给定平面上的两个格点 p1 = (x1,y1) 和 p2 = (x2,y2), 他想找出线段p1p2上除p1和p2以外一共有几个格点?但他总是数错, 你能写个程序帮帮他吗?
#include<stdio.h>
#include<math.h>
int main()
{
int x1, y1; int x2, y2;
scanf("%d %d", &x1, &y1);
scanf("%d %d", &x2, &y2);
int a = abs(x1 - x2);
int b = abs(y1 - y2);
int count = 0;
for (int i = 1; i < a + b; i++)
{
if (a % i == 0 && b % i == 0)
count++;
}
printf("%d", count);
return 0;
}
标签:10,int,scanf,++,12.13,printf,include
From: https://blog.csdn.net/2401_89524595/article/details/144461002