C语言训练之杭电OJ



一、求数列的和

Problem Description问题描述

数列的定义如下:
数列的第一项为n,以后各项为前一项的平方根,求数列的前m项的和。

Input输入

输入数据有多组,每组占一行,由两个整数n(n<10000)和m(m<1000)组成,n和m的含义如前所述。

Output输出

对于每组输入数据,输出该数列的和,每个测试实例占一行,要求精度保留2位小数。

Sample Input输入样例

81 4
2 2

Sample Output输出样例

94.73
3.41

代码如下:

#include<stdio.h>
#include<math.h>
int main()
{
	int m,n,i;
	while(~scanf("%d %d",&n,&m))
	{
		double s=n,temp=n;
		for(i=1;i<m;i++,temp=sqrt(temp))
			s+=sqrt(temp);
		printf("%.2lf\n",s);
	}
}

总结:

初时未注意到本题有多组数据输入,只读入了一组数据,写完代码审阅时发现有问题,决定把scanf("%d %d",&n,&m);改为while(~scanf("%d %d",&n,&m))。结果,修改while语句时后面多了一个(分号);编译器又没报错,提交就一直不通过,粗心大意真是要不得!

二、水仙花数

Problem Description问题描述

春天是鲜花的季节,水仙花就是其中最迷人的代表,数学上有个水仙花数,他是这样定义的:
“水仙花数”是指一个三位数,它的各位数字的立方和等于其本身,比如:153=13+53+3^3。
现在要求输出所有在m和n范围内的水仙花数。

Input输入

输入数据有多组,每组占一行,包括两个整数m和n(100<=m<=n<=999)。

Output输出

对于每个测试实例,要求输出所有在给定范围内的水仙花数,就是说,输出的水仙花数必须大于等于m,并且小于等于n,如果有多个,则要求从小到大排列在一行内输出,之间用一个空格隔开;
如果给定的范围内不存在水仙花数,则输出no;
每个测试实例的输出占一行。

Sample Input输入样例

100 120
300 380

Sample Output输出样例

no
370 371

代码如下:

#include <stdio.h>
#include<math.h>
int main()
{
    int m,n,i,sum;
    while(~scanf("%d %d",&m,&n))
    {
    	int count=0;
    	for(i=m;i<=n;i++)
    	{
    	sum = pow(i%10,3) + pow((i/10)%10,3) + pow(i/100,3);
        if(sum==i)
        {
        	count++;
        	if(count==1) printf("%d",i);
        	else printf(" %d",i);
		}
        
    	}
    if(count==0) printf("no");
    printf("\n");
	}
}

总结:

由于本题有多组数据输入,count在每组数据的for循环内都要做为判断条件,所以每一次count的值都需要初始化。开始时一直没注意到这一点,把count的赋值放在while循环前,结果测试样例能通过,提交却不能通过,思维还是不够缜密。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[2\]提供了关于如何在杭电OJ上使用C语言进行题目刷题的步骤。首先,你需要打开百度并搜索“杭电OJ”,然后进入官网进行注册。在注册界面上填写完整的信息后点击提交。接下来,你可以使用你的用户名和密码登录账号。进入刷题界面后,你可以选择C语言作为答题语言,并将代码粘贴到答题界面。然后你可以查看答案是否正确。如果你不小心离开了界面,你可以通过点击红线圈出部分或者点击右上方的用户名进入用户界面来查看你的题目是否正确。\[2\] 引用\[1\]提供了一段C语言代码,但是没有明确指出这段代码的作用和题目的具体要求。如果你能提供更多关于杭电OJ1098题目的信息,我将能够为你提供更准确的帮助。 #### 引用[.reference_title] - *1* [杭电OJ 2007 C语言版 已通过](https://blog.csdn.net/m0_56912916/article/details/119041984)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [杭电OJ刷题指南(ACM)](https://blog.csdn.net/qq_38769551/article/details/101510000)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值