|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 北笙哟 于 2021-10-27 23:33 编辑
- #include <stdio.h>
- int main()
- {
- long long int n,M;
- _Bool flag = 1;
- while(flag != 0)
- {
- scanf("%lld",&n);
- if(1 <= n && n < 1000000000)
- {
- RETURN: if(n>100)
- {
- M = n - 10;
- }
- else if(n <= 100)
- {
- if(flag = 1)
- {
- n = n + 11;
- goto RETURN;
- flag = 0;
- }
- else
- {
- goto RETURN;
- }
- }
- }
- else
- {
- flag = 0;
- }
- printf("%lld\n",M);
- }
- return 0;
- }
复制代码
难道是递归浪费了时间?
再试试这个呢?
- #include <stdio.h>
- unsigned long long foo(unsigned long long d)
- {
- return (d > 100) ? d - 10 : foo(d + 11) ;
- }
- unsigned long long foo2(unsigned long long d)
- {
- while(d <= 100) d += 11 ;
- return d - 10 ;
- }
- int main(void)
- {
- char s[256] ;
- unsigned long long d[256] , i , n ;
- for(n = 0 ;;) {
- gets(s) ;
- if(s[0]) sscanf(s , "%llu" , & d[n ++]) ;
- else break ; // 按下空回车键结束输入
- }
- for(i = 0 ; i < n ; i ++) printf("%llu\n" , foo2(d[i])) ;
- }
复制代码
|
|