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;
	
	
}
运行结果:

原文:http://www.cnblogs.com/xiao-lan-mao/p/7308613.html