1,计算数组中完数的个数
【完数:除本身约数和等于本身。例如6:1 23 1+2+3=6 例如:28:1+2+4+7+14=18】
【函数封装】
在该函数【void PerfectFun(int arr[],int n) 】循环数组每一个值
在该函数【int Perfect(int num) 】 判断完数,返回约数的和
#include <stdio.h>
#include <string.h>
//判断是否为完数,如果是,返回数值,不是,返回0
int wan_shu(int num)
{
int sum = 0;
for (int i = 1; i < num; i++)
{
if (num % i == 0) //能被其他数整除,有约数
{
sum += i;
}
}
//总和等于本身,是完数
if (sum == num)
{
return sum;
}
else
{
return 0;
}
}
//循环数组中的每个元素
void xun_huan(int arr[], int len)
{
printf("数组中的完数有:\n");
for (int i = 0; i < len; i++)
{
if (arr[i] == wan_shu(arr[i]))
{
printf("%d\t", arr[i]);
}
}
printf("\n");
}
int main()
{
int arr[] = { 25, 35, 6, 56, 87, 15, 28, 99, 82, 65,125, 258, 496, 1,567, 357, 86, 8128, 13, 15, 123, 159 };
int len = sizeof(arr) / sizeof(arr[0]);
xun_huan(arr, len);
return 0;
}
2,实现单词的逆置 “hello my student”
最终结果是”student my hello”
在该函数【void StrFun( char str[]) 】 循环字符串的
在该函数【void StrRev(char str[]) 】 主要是实现逆置的
#include <stdio.h>
#include <string.h>
//循环字符串
void str_xun_huan(char str[])
{
int len = strlen(str);
int j = len - 1;
char temp;
for (int i = 0; i < j; i++)
{
temp = str[i];
str[i] = str[j];
str[j] = temp;
j--;
}
}
//逆置
void strrev1(char str[])
{
int m = 0, n = 0, t;
char temp1;
while (str[m] != '\0')
{
while (str[n] != '\0' && str[n] != ' ') //当str[j]不在每个单词的结束(即寻找每个单词结束时的j值)此时 '\0'下标
{
n++;
}
t = n - 1; //记录此时单词末尾的下标
//部分单词的逆置,此处应该为一个循环,不能仅仅时if判断
while (m < t)
{
temp1 = str[m];
str[m] = str[t];
str[t] = temp1;
m++; t--;
}
//n遇到空格后,接着往下运行
while (str[n] == ' ')
{
n++;
}
m = n; //知道遇到下一个单词的首字母,此时的下标
}
}
int main()
{
char str[] = "hello my student";
str_xun_huan(str);
strrev1(str);
puts(str);
return 0;
}