函数的练习

1、实现一个函数,判断整数是否是素数,调用该函数显示出100~10000之间的所有素数

#include <stdio.h>
int sushu(int a);
int main(int argc,const char* argv[])
{
    int i,sum=0,a;
    for(i=100;i<10000;i++)
    {
        a=sushu(i);
        if(a==1)
        {
            printf("%d ",i);
            sum++;
        }
    }
    printf("\n%d",sum);
}
int sushu(int a)
{
    int i,result;
    for(i=2;i<=a/2;i++)
    {
        if(a%i==0) break;
    }
    if(i>a/2)
    {
        result=1;
    }
    else result=0;
    return result;
}

 2、输入两个日期,计算两个日期之间间隔了多少天

#include <stdio.h>
int time(int year,int month,int day);
int main(int argc,const char* argv[])
{
    int i,year1,month1,day1,n,year2,month2,day2,days;
    scanf("%d",&n);
    for(i=1;i<=n;i++)
    {
        scanf("%d-%d-%d",&year1,&month1,&day1);
        scanf("%d-%d-%d",&year2,&month2,&day2);
        days=(year2-year1)*365+(year2-year1)/4-(year2-year1)/100+(year2-year1)/400-time(year1,month1,day1)+time(year2,month2,day2);
    if(days<0) days=-days;
    printf("%d\n",days);
    }
}
int time(int year,int month,int day)
{
    int sum,i;
    sum=0;
    int a[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
    for(i=1;i<month;i++)
    {
        sum=sum+a[i];
    }
    if(year%4==0&&year%100!=0&&year%400==0)
    {
        if(month>2||month==2&&day>28)    sum=sum+1;
    }
    sum=sum+day;
    return sum;
}

 3、实现一个函数,判断整数是否是回文数,调用该函数显示出1亿-10亿之间的所有回文数

#include <stdio.h>
int back(int num);
int main(int argc,const char* argv[])
{
    int i,sum=0;
    for(i=100000000;i<1000000000;i++)
    {
        if(back(i)==1)
        {
            printf("%d ",i);
            sum++;
        }
    }
    printf("\n%d",sum);
}
int back(int num)
{
    int i=0,a[12],j,result=1;
    while(num!=0)
    {
        a[i]=num%10;
        num=num/10;
        i++;
    }
    for(j=i-1;j>i/2;j--)
    {
        if(a[j]!=a[i-j-1]) result=0;
    }
    return result;
}

 4、计算出100的阶乘

#include <stdio.h>
int num(int n);
int a[256]={1,0};
int main(int argc,const char* argv[])
{
    int n,i;
    int sum;
    while(scanf("%d",&n)!=EOF)
    {
        a[0]=1;
        for(i=1;i<256;i++) a[i]=0;
        sum=num(n);
        for(i=sum-1;i>=0;i--)
        {
            printf("%d",a[i]);
        }
        printf("\n%d\n",sum);
    }
}
int num(int n)
{

    int i,wei,j,sum=1;
    for(i=1;i<=n;i++)
    {
        for(j=0;j<256;j++)
        {
            a[j]=a[j]*i;
        }
        for(j=0;j<256;j++)
        {
            if(a[j]>100)
            {
                a[j+2]=a[j+2]+a[j]/100;
                a[j]=a[j]%100;
            }
            if(a[j]>10)
            {
                a[j+1]=a[j+1]+a[j]/10;
                a[j]=a[j]%10;
            }
        }
    }
    for(i=256;i>=0;i--)
    {
        if(a[i]!=0)
        {
            sum=i+1;break;
        }
    }
    return sum;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
编写Python函数练习题可以帮助您提高对Python函数的理解和运用能力。以下是一些Python函数练习题的示例: 1. 编写一个函数,接受用户输入的两个数字,并返回它们的和。您可以使用下面的代码作为参考: ```python def add_numbers(a, b): return a + b num1 = int(input("请输入第一个数字: ")) num2 = int(input("请输入第二个数字: ")) result = add_numbers(num1, num2) print("两个数字的和为:", result) ``` 2. 编写一个函数,接受用户输入的字符串,并将其中的字符倒序输出,但保留标点符号的位置不变。例如,将字符串"I enjoy reading!"经过函数调用后变为"!gnidaer yojne I"。您可以使用下面的代码作为参考: ```python def reverse_string(string): punctuation = ['!', ',', '.', '?'] # 标点符号列表 new_string = '' for i in range(len(string)): if string[i in punctuation: # 如果字符是标点符号,则保持位置不变 new_string += string[i] else: new_string += string[len(string)-i-1 # 其他字符倒序输出 return new_string user_input = input("请输入一个字符串: ") result = reverse_string(user_input) print("倒序输出后的字符串为:", result) ``` 3. 编写一个函数,接受用户输入的一个数字n,然后输出小于等于n的所有H(n)值。H(n)是指将一个数的各个数位的平方相加,然后再重复这个过程,直到最后得到的数字是1或者循环结束。您可以使用以下代码作为参考: ```python def calculate_hn(n): hn_values = [] for i in range(n+1): num = i while num != 1 and num != 4: # H(n)的循环结束条件是1或者循环结束 num = sum(int(digit)**2 for digit in str(num)) if num == 1: hn_values.append(i) return hn_values user_input = int(input("请输入参数n: ")) result = calculate_hn(user_input) print("H(n)小于等于参数n的所有值为:", result) ``` 4. 编写一个函数,实现折半查找。折半查找是一种在有序列表中查找指定元素的方法,通过将列表分成两半并比较中间值来确定要查找的元素在哪一半中。您可以使用以下代码作为参考: ```python def binary_search(array, target): low = 0 high = len(array) - 1 while low <= high: mid = (low + high) // 2 if array[mid == target: return mid elif array[mid < target: low = mid + 1 else: high = mid - 1 return -1 numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] target_number = int(input("请输入要查找的数字: ")) result = binary_search(numbers, target_number) if result != -1: print("数字在列表中的索引位置为:", result) else: print("数字不在列表中") ``` 希望这些示例可以帮助您开始练习Python函数。如果您有更多的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值