中国大学MOOC-翁恺-C语言-PAT习题及解答-第八周

08-0. 查找整数(10)

本题要求从输入的N个整数中查找给定的X。如果找到,输出X的位置(从0开始数);
如果没有找到,输出“Not Found”。

输入格式:输入在第1行中给出2个正整数N(<=20)和X,第2行给出N个整数。数字均不
超过长整型,其间以空格分隔。
输出格式:在一行中输出X的位置,或者“Not Found”。

输入样例1:5 7
3 5 7 1 9
输出样例1:2
输入样例2:5 7
3 5 8 1 9
输出样例2:Not Found

#include <stdio.h>

int main()
{
   
   
	int n,x;
	int flag = 1;
	printf("please input : ");
	scanf("%d %d", &n, &x);
	int arr[n];
	for(int i=0; i<n; i++){
   
    
		// int a;
		// scanf("%d", &a);
		// arr[i] = a;
		scanf("%d", &arr[i]);
	}
	for(int i=0; i<n; i++){
   
   
		if(arr[i] == x){
   
   
			flag = 0;
			printf("address : %d", i);
		}
	}
	if(flag) printf("Not Found");
	return 0;
}

08-1. 求一批整数中出现最多的个位数字(20)

给定一批整数,分析每个整数的每一位数字,求出现次数最多的个位数字。例如给定3个整数1234、
2345、3456,其中出现最多次数的数字是3和4,均出现了3次。

输入格式:输入在第1行中给出正整数N(<=1000),在第2行中给出N个不超过整型范
围的正整数,数字间以空格分隔。
输出格式:在一行中按格式“M: n1 n2 …”输出,其中M是最大次数,n1、n2、……为出现
次数最多的个位数字,按从小到大的顺序排列。数字间以空格分隔,但末尾不得有多余空格。

输入样例:3
1234 2345 3456
输出样例:3: 3 4

#include <stdio.h>

int main()
{
   
   
	int n,a;
	int s=0;	//计算共有多少个数字
	int arr[100];	//存放输入的整数拆分出来的个位数
	int number[10] = {
   
   0};	//索引即数,对应的值即为其个数

	printf("please input : ");
	scanf("%d", &n);
	for<
### 关于中国大学MOOC翁恺C语言程序设计习题集的相关资源 在中国大学MOOC平台上,翁恺老师的《程序设计入门——C语言》课程因其高质量的教学内容而广受好评。该课程不仅提供了理论讲解,还通过丰富的练习帮助学习者巩固知识点[^1]。 对于希望获取更多习题及相关解答的学习者而言,可以参考以下几种方式: #### 1. **官方配套教材** 翁恺老师在其课程中推荐了一些经典的C语言书籍作为辅助材料。这些书通常会附带大量习题及其解析,能够有效补充线上课程的内容。例如,《C程序设计语言(第二版)》是一本经典教材,适合初学者深入理解C语言的核心概念[^4]。 #### 2. **社区讨论区** 每门MOOC课程都设有专门的论坛供学员交流心得与疑问。在“程序设计入门——C语言”的讨论区内,许多同学分享了自己的解题思路以及常见错误分析。积极参与此类互动不仅能解决具体问题,还能提升编程思维能力[^1]。 #### 3. **第三方网站上的整理资料** 网络上有不少热心网友基于个人学习经验总结出了完整的习题答案集合或者技巧指南。不过需要注意的是,在查阅他人成果时应注重理解和应用而非单纯抄袭;同时也要甄别信息来源的真实性以免受到误导。比如下面这个简单的位运算例子展示了如何正确打印十六进制值并演示左移操作效果[^2]: ```c #include <stdio.h> int main() { unsigned char c = 0xA5; printf("c=%hhx\n", c); printf("c<<2=%hhx\n", c << 2); return 0; } ``` #### 4. **开发环境的选择建议** 为了更好地完成课后作业,选择合适的集成开发环境(IDE)至关重要。针对不同操作系统平台,可以选择如下工具之一来编写和调试代码:MS Visual Studio Express适用于Windows用户;MacOS X 用户则可选用Xcode;跨平台解决方案包括Eclipse-CDT、Geany搭配MinGW等轻量级选项也十分实用[^4]。 #### 5. **编译过程的理解有助于排查错误** 了解整个程序从源码到最终运行版本之间的转换流程可以帮助开发者快速定位潜在问题所在位置。一般情况下,这一链条涉及以下几个阶段:.c 文件经由预处理器生成.i文件,.i再交予编译器产出.s汇编代码,.s进一步转化为.o目标模块最后链接成.out可执行二进制文件[^3]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hao难懂

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值