C语言 编程题

C语言学习!

        1.小明上课需要走n阶台阶,他每次可以选择走一阶或者走两阶,他一共有多少种走法?

输入描述:输入包含一个整数n(1 ≤ n ≤30)

输出描述:输出一个整数,即小明可以走的方法数。

代码示例:

#include <stdio.h>

int fig(int n)
{
	if (n <= 2)
	{
		return n;
	}
	else
	{
		return fig(n - 1) + fig(n - 2);
	}
}

int main()
{
	int n = 0;
	scanf("%d", &n);//输入
	int ret = fig(n);//计算
	printf("%d\n", ret);//输出
	return 0;
}

运行结果:

2
2
10
89

        2.有一个整数序列(可能有重复的整数),现删除指定的某一个整数,输出删除指定数字之后的序列,序列中未被删除数字的前后位置没有发生改变。

数据范围:序列长度和序列中的值都满足 1 ≤ n ≤ 50

输入描述:

  • 第一行输入一个整数(1 ≤ n ≤ 50)。
  • 第二行输入N个整数,输入用空格分隔的N个整数。
  • 第三行输入想要进行删除的一个整数。

输出描述:输出为一行,删除指定数字之后的序列。

代码示例:

#include <stdio.h>
int main()
{
	int n = 0;
	scanf("%d", &n);//接收n个数字
	int arr[50] = { 0 };
	int i = 0;
	for (i = 0; i < n; i++)
	{
		scanf("%d", &arr[i]);
	}
	int del = 0;
	scanf("%d", &del);//接收删除的数据
	int j = 0;//j作为下标锁定的位置,用来存放不删除的数据
	for (i = 0; i < n; i++)
	{
		if (arr[i] != del)
		{
			arr[j++] = arr[i];
		}
	}
	for (i = 0; i < j; i++)//输出
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

运行结果:

6
5 7 6 9 5 8
5
7 6 9 8

        3.输出n个成绩,换行输出n个成绩中最高分和最低分的差。

输入描述:

  • 两行。第一行为n,表示n个成绩,不会大于10000.
  • 第二行为n个成绩(整数表示,范围0~100),以空格隔开。

输出描述:一行,输出n个成绩中最高分数和最低分数的差。

代码示例:

#include <stdio.h>
int main()
{
	int n = 0;
	scanf("%d", &n);
	int arr[10000] = { 0 };
	int i = 0;
	for (i = 0; i < n; i++)//输入
	{
		scanf("%d", &arr[i]);
	}
	int max = 0;
	int mix = 100;
	for (i = 0; i < n; i++)//比较出最大值和最小值
	{
		if (arr[i] < mix)
		{
			mix = arr[i];
		}
		if (arr[i] > max)
		{
			max = arr[i];
		}

	}
	printf("%d", max - mix);//输出

	return 0;
}

运行结果:

6
66 88 60 87 99 80
39

        4.字母大小写转换,有一个字符,判断它是否为大写字母,如果是,将它转换成小写字母;反之则转换为大写字母。

输入描述:多组输入,每一行输入一个字母。

输出描述:针对每组输入,输出单独占一行,输出字母的对应形式。

代码示例1:

#include <stdio.h>
int main()
{
	char n = 0;
	while(scanf("%c", &n)==1)
	{
		if (n >= 'a' && n <= 'z')
		{
			printf("%c\n", n - 32);
		}
		else if (n >= 'A' && n <= 'Z')
		{
			printf("%c\n", n + 32);
		}
	}
	return 0;
}

运行结果:

a
A
G
g
f
F
H
h

代码示例2:

#include <ctype.h>
#include <stdio.h>
int main()
{
	char n = 0;
	while(scanf("%c", &n)!=EOF)
	{
		if (islower(n))//islower函数判断是否是小写字母,是返回1
		{
			printf("%c\n", toupper(n));//toupper函数可将小写字母转大写
		}
		else if (isupper(n))//isupper函数判断是否是大写字母,是返回1
		{
			printf("%c\n", tolower(n));//tolower函数可将大写字母转小写
		}
	}
	return 0;
}

运行结果:

a
A
b
B
G
g
T
t

分析:scanf函数读取成功时,返回读取的数据个数;读取失败时,返回EOF。


        5.判断输入的字符是不是字母。

输入描述:多组输入,每一行输入一个字符。

输出描述:针对每组输入,输出但独占一行,判断输入字符是否为字母,输出内容详见输出样例。

输出样例:

a
a is an alphabet.
*
* is not an alphabet.

代码示例1:

#include <stdio.h>
int main()
{
	char ch = 0;
	while (scanf("%c", &ch) == 1)
	{
		if ((ch >= 'a' && ch <= 'z') || (ch >= 'A' && ch <= 'Z'))
		{
			printf("%c is an alphabet.\n", ch);
		}
		else
		{
			printf("%c is not an alphabet.\n", ch);
		}
		getchar( );//用于处理输入字符末尾的\n
	}
	return 0;
}

运行结果:

5
5 is not an alphabet.
D
D is an alphabet.
a
a is an alphabet.
*
* is not an alphabet.

分析:

        getchar( );用于处理输入字符末尾的\n

代码示例2:

#include <stdio.h>
int main()
{
	char ch = 0;
	while (scanf(" %c", &ch) == 1)//%c前面加空格,是为了跳过下一个字符之前的所有空白字符\n
	{
		if (isalpha(ch))// isalpha函数用于判断是否为字母,是输出1.
		{
			printf("%c is an alphabet.\n", ch);
		}
		else
		{
			printf("%c is not an alphabet.\n", ch);
		}
	}
	return 0;
}

运行结果:

#
# is not an alphabet.
G
G is an alphabet.
c
c is an alphabet.
9
9 is not an alphabet.

分析:

        scanf中%c前面加空格,是为了跳过下一个字符之前的所有空白字符\n

        isalpha函数用于判断是否为字母,是输出1.


        6.变种水仙花数:把任意的数字从中间拆分成两个数字,如1461可拆分为1和461;14和61;146和1,若所有拆分后的乘积之和等于自身则是一个水仙花数。

1461=1*461 + 14*61 + 146*1

求出5位数中的所有水仙花数。

代码示例:

#include <stdio.h>
#include <math.h>

int main()
{
	int i = 0;
	for (i = 10000; i < 99999; i++)
	{
		int j = 0;
		int sum = 0;
		for (j = 1; j <= 4; j++)
		{
			int k = (int)pow(10, j);
			sum += (i / k) * (i % k);
		}
		if (sum == i)
		{
			printf("%d ", i);
		}
		
	}
	return 0;
}

运行结果:

14610 16420 23610 34420 65500

相关推荐

  1. C语言 编程

    2023-12-13 15:54:01       41 阅读
  2. C语言编程-单身狗

    2023-12-13 15:54:01       36 阅读
  3. c语言编程经典100例——(90~95例)

    2023-12-13 15:54:01       34 阅读
  4. C语言常见面试C语言中如何进行网络编程

    2023-12-13 15:54:01       28 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-13 15:54:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-13 15:54:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-13 15:54:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-13 15:54:01       20 阅读

热门阅读

  1. 通过compileall库将python文件编译为pyc文件

    2023-12-13 15:54:01       37 阅读
  2. Git常用命令大全

    2023-12-13 15:54:01       37 阅读
  3. uni-app点击预览图片

    2023-12-13 15:54:01       43 阅读
  4. CSS新手入门笔记整理:CSS清除浮动的方法

    2023-12-13 15:54:01       37 阅读
  5. Redis各种数据结构应用场景

    2023-12-13 15:54:01       39 阅读
  6. ARM day7

    ARM day7

    2023-12-13 15:54:01      42 阅读
  7. Vue宝典之自定义组件声明与使用

    2023-12-13 15:54:01       31 阅读