涉及数组的C语言程序代码,C语言复习——一维数组部分程序(示例代码)

1.求一个数组中最值和最值所在数组中的下标。

程序如下:

#include

#pragma warning(disable:4996);//在VS中编译时由于使用了scanf函数警告不安全,无法通过,此语句是为了消除这个警告

int main()

{

int a[5];

int max,min;

int index1,index2;

printf("请输入数组元素值:");

for (int j= 0; j<5; j++)

{

scanf("%d",&a[j]);

}

max = a[0];

min = a[0];

index1 = 0;

index2 = 0;

for (int i = 1; i < 5; i++)

{

//找出最大值及最大值下标

if (max < a[i])

{

max = a[i];

index1 = i;

}

//找出最小值及最小值下标

if (min>a[i])

{

min = a[i];

index2 = i;

}

}

printf("最大值为:%d\n", max);

printf("最大值下标为:%d\n", index1);

printf("最小值为:%d\n", min);

printf("最小值下标为:%d\n", index2);

return 0;

}

运行结果:

57e1d310ae0ac50977a7d634d21f6fba.png

2.数组逆置问题

如图:

1820f3936e6bc8e3dd69cc63a34db9a0.png

#include

#pragma warning(disable:4996);

int main()

{

int a[5];

int max=4,min=0;

printf("请输入数组元素值:");

for (int j= 0; j<5; j++)

{

scanf("%d",&a[j]);

}

while (max > min)//使用while循环

{

int t;

t = a[min];

a[min] = a[max];

a[max] = t;

max--;

min++;

}

printf("数组逆置后为:");

for (int i = 0; i < 5; i++)

{

printf("%d", a[i]);

}

printf("\n");

return 0;

}

或者也可以采用以下代码实现:

#include

#pragma warning(disable:4996);

int main()

{

int a[5];

printf("请输入数组元素值:");

for (int j= 0; j<5; j++)

{

scanf("%d",&a[j]);

}

for(int i=0;i<2;i++)

{

int t;

t = a[i];

a[i] = a[4-i];

a[4-i] = t;

}

printf("数组逆置后为:");

for (int i = 0; i < 5; i++)

{

printf("%d", a[i]);

}

printf("\n");

return 0;

}

运行结果:

a50470ce5772b541a5d10461a2564d60.png

3.水仙花数问题

描述:若一个n位数的数值等于每一位上数字的n次方之和,则这个数为水仙花数。

如:153=1*1*1+5*5*5+3*3*3

问题:求100到999之间的所有水仙花数。

代码实现:

#include

#pragma warning(disable:4996);

int main()

{

int n1, n2, n3;

printf("100至999之间的水仙花数为:\n");

for (int num = 100; num < 1000; num++)

{

n1 = num / 100;//得到百位上的数字

n2 = (num % 100) / 10;//得到十位上的数字

n3 = num - n1 * 100 - n2 * 10;//得到个位上的数字

if ((n1*n1*n1 + n2*n2*n2 + n3*n3*n3) == num)

{

printf("%d ",num);

}

}

printf("\n");

return 0;

}

运行结果:

a470a65b57ddaf080f9bed1d4735574a.png

4.求3到100之间的所有素数(除了1和自身外不能被其他整数整除的整数)

代码实现:

#include

#pragma warning(disable:4996);

int main()

{

printf("3至100之间的素数为:\n");

for (int num = 3; num < 100; num++)

{

int flag = 0;//素数标志

for (int i = 2; i < num; i++)

{

if ((num%i)== 0)//说明不是素数

flag = 1;

break;

}

if (flag == 0)

{

printf("%d ", num);

}

}

printf("\n");

return 0;

}

运行结果:

33741120eb37dcf9a28bb0ff246c99fc.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值