标签:blog 技术分享 之间 http img 组元 .com bre 最大
1.求一个数组中最值和最值所在数组中的下标。
程序如下:
#include<stdio.h> #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; }
运行结果:
2.数组逆置问题
如图:
#include<stdio.h> #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<stdio.h> #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; }
运行结果:
3.水仙花数问题
描述:若一个n位数的数值等于每一位上数字的n次方之和,则这个数为水仙花数。
如:153=1*1*1+5*5*5+3*3*3
问题:求100到999之间的所有水仙花数。
代码实现:
#include<stdio.h> #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; }
运行结果:
4.求3到100之间的所有素数(除了1和自身外不能被其他整数整除的整数)
代码实现:
#include<stdio.h> #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; }
运行结果:
标签:blog 技术分享 之间 http img 组元 .com bre 最大
原文地址:http://www.cnblogs.com/xiao-lan-mao/p/7308613.html