#include <stdio.h>
int main(int argc, char *argv[])
{
int a[3][3], sum = 0;
printf(“\n请输入矩阵元素值(3*3):\n”);
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
scanf_s(“%d”, &a[i][j]);
}
}
printf(“\n输出矩阵(3*3)数据如下:\n”);
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
printf(“%4d”, a[i][j]);
}
printf(“\n”);
}
printf(“\n”);
// 求对角线之和
for (int i = 0; i < 3; i++)
sum = sum + a[i][i];
printf(“\n矩阵对角线(3*3)元素之和为:%d\n\n”, sum);
return 0;
}
【运行效果】:
006、【题目】求素数。
判断101-200之间有多少个素数,并输出所有素数。
【程序分析】:
判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。
【程序源码】:
/*********************************************
运行平台:Windows 10企业版
开发工具:Visual Studio 2017
编程语言:C语言
整理作者:Sirius
修改日期:2020年2月8日
**********************************************/
#include “stdafx.h”
#include <stdio.h>
#include <math.h>
int _tmain(int argc, _TCHAR* argv[])
{
int m, i, k, h = 0, leap = 1;
printf(“\n”);
for (m = 101; m <= 200; m++)
{
k = sqrt(double(m + 1));
for (i = 2; i <= k; i++)
if (m%i == 0)
{
leap = 0; break;
}
if (leap) {
printf(“%-4d”, m); h++;
if (h % 10 == 0)
printf(“\n”);
}
leap = 1;
}
printf(“\n101到200之间共计有: %d个素数\n\n”, h);
return 0;
}
【运行效果】:
007、【题目】分解质因数。
将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。
【程序分析】:
对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:
(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。
(2)如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,
重复执行第一步。
(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。
【程序源码】:
/*********************************************
运行平台:Windows 10企业版
开发工具:Visual Studio 2017
编程语言:C语言
整理作者:Sirius
修改日期:2020年2月8日
**********************************************/
#include <stdio.h>
int main()
{
int n, i;
printf(“\nplease input a number:\n”);
scanf_s(“%d”, &n);
printf(“%d=”, n);
for (i = 2; i <= n; i++)
{
while (n != i)
{
if (n%i == 0)
{
printf(“%d*”, i);
n = n / i;
}
else
break;
}
}
printf(“%d”, n);
return 0;
}
【运行效果】:
008、【题目】完数。
一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3.编程找出1000以内的所有完数。
【程序分析】:参考源代码
【程序源码】:
/*********************************************
运行平台:Windows 10企业版
开发工具:Visual Studio 2017
编程语言:C语言
整理作者:Sirius
修改日期:2020年2月8日
**********************************************/
#include <stdio.h>
int main()
{
static int k[10];
int i, j, n, s;
for (j = 2; j < 1000; j++)
{
n = -1;
s = j;
for (i = 1; i < j; i++)
{
if ((j%i) == 0)
{
n++;
s = s - i;
k[n] = i;
}
}
if (s == 0)
{
printf(“%5d is a wanshu”, j);
for (i = 0; i < n; i++)
printf(“%5d,”, k[i]);
printf(“%5d\n”, k[n]);
}
}
return 0;
}
【运行效果】:
009、【题目】最大公约数和最小公倍数。
输入两个正整数m和n,求其最大公约数和最小公倍数。
【程序分析】:
利用辗除法
【程序源码】:
/*********************************************
运行平台:Windows 10企业版
开发工具:Visual Studio 2017
编程语言:C语言
整理作者:Sirius
修改日期:2020年2月8日
**********************************************/
#include <stdio.h>
int main()
{
int a, b, num1, num2, temp;
printf(“请输入两个整数:\n”);
scanf_s(“%d,%d”, &num1, &num2);
if (num1 < num2)
{
temp = num1;
num1 = num2;
num2 = temp;
}
a = num1; b = num2;
while (b != 0)/*利用辗除法,直到b为0为止*/
{
temp = a % b;
a = b;
b = temp;
}
printf(“最大公约数:%d\n”, a);
printf(“最小公倍数:%d\n”, num1*num2 / a);
return 0;
}
【运行效果】:
010、【题目】三个数由小到大输出。
【程序分析】:
我们想办法把最小的数放到x上,先将x与y进行比较,如果x>y则将x与y的值进行交换,然后再用x与z进行比较,如果x>z则将x与z的值进行交换,这样能使x最小。
【程序源码】:
/*********************************************
运行平台:Windows 10企业版
开发工具:Visual Studio 2017
编程语言:C语言
整理作者:Sirius
修改日期:2020年2月8日
**********************************************/
#include <stdio.h>
int main()
{
int x, y, z, t;
printf(“请输入三个整数:\n”);
scanf_s(“%d%d%d”, &x, &y, &z);
if (x > y)
{
t = x; x = y; y = t;
} /*交换x,y的值*/
if (x > z)
{
t = z; z = x; x = t;
}/*交换x,z的值*/
if (y > z)
{
t = y; y = z; z = t;
}/*交换z,y的值*/
printf(“从小到大输出结果为: %d %d %d\n”, x, y, z);
return 0;
}
【运行效果】:
********************/
#include <stdio.h>
int main()
{
int x, y, z, t;
printf(“请输入三个整数:\n”);
scanf_s(“%d%d%d”, &x, &y, &z);
if (x > y)
{
t = x; x = y; y = t;
} /*交换x,y的值*/
if (x > z)
{
t = z; z = x; x = t;
}/*交换x,z的值*/
if (y > z)
{
t = y; y = z; z = t;
}/*交换z,y的值*/
printf(“从小到大输出结果为: %d %d %d\n”, x, y, z);
return 0;
}
【运行效果】:
[外链图片转存中…(img-eWkHqmuQ-1725682238493)]
[外链图片转存中…(img-WPdPXtCu-1725682238494)]
[外链图片转存中…(img-1kEDO0Uv-1725682238494)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上运维知识点,真正体系化!