热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

c语言超难例题,c语言高难度编程题

本文目录一览:1、c语言超难题目(对我来说)2

本文目录一览:


  • 1、c语言超难题目(对我来说)


  • 2、求问一道超难的C语言题


  • 3、C语言超难的题


  • 4、10道经典的C语言例题(含参考程序)

c语言超难题目(对我来说)

同学还是好学的哦

#includestdio.h

viod main()

{

long i; //利润大于65535了

int bonus1,bonus2,bonus4,bonus6,bonus10,bonus; //奖金就用int了不会超的

scanf("%ld",i);

bonus1=100000*0.1; //分别把10-100万之间的奖金表达式列出

bonus2=bonus1+100000*0.75;

bonus4=bonus2+200000*0.5;

bonus6=bonus4+200000*0.3;

bonus10=bonus6+400000*0.15;

if(i=100000) bOnus=i*0.1; //if的嵌套可以做到选择的目的,每次下面多出的部分都可以用上面的表达式表示出来

else if(i=200000)

bOnus=bonus1+(i-100000)*0.075;

else if(i=400000)

bOnus=bonus2+(i-200000)*0.05;

else if(i=600000)

bOnus=bonus4+(i-400000)*0.03;

else if(i=1000000)

bOnus=bonus6+(i-600000)*0.015;

else

bOnus=bonus10+(i-1000000)*0.01;

printf("bOnus=%d",bonus);

}

求问一道超难的C语言题

#includestdio.h

#includestring.h

#includestdlib.h

#define ARR_SIZE 20  //array数组大小 

int getkey(int key[]);

int getarray(int array[]);

int insert(int array[],int key,int vol);

int result(int flag);

int main()

{

    int M,n,flag,vol;

    int array[ARR_SIZE];

    int *key;

    memset(array,0,sizeof(array));//初始化数组为0 

    printf("请输入M:\n");

    scanf("%d",M);

    while(M)//循环M次 

    {

        getarray(array);

        printf("请输入n:\n");

        scanf("%d",n);

        key=(int *)malloc(n);//根据输入n申请数组大小 

        //将数组大小放入数组首位,主要由于你给的 getkey(int key[])只

        //有一个参数,无法传递数组大小,因此放到手位置传递 

        key[0]=n;

        getkey(key);

        for(int i=0;i!=n;i++)//key[]中有n个值,因此n次判断 

        {

            result(insert(array,key[i],ARR_SIZE));

        }

        memset(array,0,sizeof(array));//清空数组,为下次数据准备 

        M--;

    }

}

int getarray(int array[])

{

    printf("\n请输入array[](=%d):\n",ARR_SIZE);

    int tmp,i=0;

    while(1)

    {

        scanf("%d",tmp);

        if(tmp==0)

            return 0;

        array[i]=tmp;

        i++;

    }

}

int getkey(int key[])

{

    int num=key[0];

    for(int i=0;i!=num;i++)

        scanf("%d",key++);

}

int insert(int array[],int key,int vol)

{

    int now_size=0,p=0;

    for(int i=0;i!=ARR_SIZE;i++) 

    {

        if(array[i])     

            now_size++;//统计array[]数组值的个数 

        if(array[i]==key)

            return -2;//    The key is already in this array!

        if(keyarray[i]array[i])

            p++;    //该位置就是需要插入的位置 

    }

    if(now_size==ARR_SIZE)

        return -1;//The array if full!

    for(int i=now_size;i=p;i--)

        array[i+1]=array[i];

    array[p]=key;

    return p;    //返回插入位置 

}

int result(int flag)

{

    if(flag==-1)

        printf("The array if full!  ");

    else if(flag==-2)

        printf("The key is already in this array!  ");

    else

        printf("The key  is inserted in position %d  ",flag);

}

昨天写好没测试,今天测了才发给你。这道题目确实不难,只是题目长。另外关于输出格式有点含糊,如果我理解有偏差,你看了我的代码改下就好。主要逻辑都已经实现了。

C语言超难的题

对你给的5分我作出以下解答:

第一题:动态规划求最长非降子序列或最长非升子序列;

第二题:搜索……

10道经典的C语言例题(含参考程序)

1.打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。例如,153是一个“水仙花数”,因为153=1^3+5^3+3^3。

#include

#include

int main()

{

int bai_wei,shi_wei,ge_wei,i,sum=0;

for(i=100;i1000;i++)

{

bai_wei=i/100;

shi_wei=(i%100)/10;

ge_wei=i%10;

if(i==pow(bai_wei,3)+pow(shi_wei,3)+pow(ge_wei,3))

{

printf("%d ",i);

sum++;

if(sum%5==0)

printf(" ");

}

}

printf(" ");

return 0;

}

2.请输入任意两个整数x和y,求其最大公约数和最小公倍数。

#include

int main()

{

int x,y,min,max,i;

printf("请输入任意两个整数:");

scanf("%d%d",x,y);

min=xy?y:x;

max=xy?x:y;

for(i=min;i0;i--)

if(x%i==0y%i==0)

{

printf("这两个整数的最大公约数为:%d ",i);

break;

}

for(i=max;i=x*y;i++)

if(i%x==0i%y==0)

{

printf("这两个整数的最小公倍数为:%d ",i);

break;

}

return 0;

}

3.输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。

#include

#include

#define N 50

int main()

{

int sum1=0,sum2=0,sum3=0,sum4,i=0;

char str[N];

printf("请输入一串字符串:");

scanf("%s",str);

for(i=0;istrlen(str);i++) p="" /strlen(str);i++)

{

if((str[i]='a'str[i]='A'str[i]='Z'))

sum1++;

if(str[i]==' ')

sum2++;

if(str[i]='0'str[i]='9')

sum3++;

}

sum4=strlen(str)-sum1-sum2-sum3;

printf("英文字母的个数:%d ",sum1);

printf("空格的个数:%d ",sum2);

printf("数字的个数:%d ",sum3);

printf("其他符号的个数:%d ",sum4);

return 0;

}

4.求s=a+aa+aaa+aaaa+aa…a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制。

#include

#include

int main()

{

int a,n,s=0,i,x=0,y=0;

printf("请输入整数a的值:");

scanf("%d",a);

printf("请输入相加的个数n:");

scanf("%d",n);

for(i=0;in;i++) p="" /n;i++)

{

x=y+2*pow(10,i);

y=x;

s=s+x;

}

printf("s=%d ",s);

return 0;

}

5.一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3。编程找出1000以内的所有完数。

#include

int main()

{

int sum=0,i,j;

printf("在1000以内的完数有:");

for(i=2;i=1000;i++)

{

for(j=1;ji;j++) p="" /i;j++)

if(i%j==0)

sum=sum+j;

if(sum==i)

printf("%d ",i);

sum=0;

}

printf(" ");

return 0;

}

6.输入一个不多于5位的正整数,要求:1、求它是几位数;2、逆序打印出个位数字。

#include

int pows(int a,int n)

{

int sum=1,i;

for(i=0;in;i++) p="" /n;i++)

sum=sum*a;

return sum;

}

int main()

{

int n,i,k,x;

printf("n=");

scanf("%d",n);

for(i=1;i6;i++)

if(n/pows(10,i)==0)

{

printf("%d ",i);

k=i;

break;

}

for(i=0;ik;i++) p="" /k;i++)

{

x=n/pows(10,i)%10;

printf("%d",x);

}

printf(" ");

return 0;

}

7.输入一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。

#include

int main()

{

int n,a[5],i=0;

printf("请输入一个5位数:");

scanf("%d",n);

while(n!=0)

{

a[i]=n%10;

n=n/10;

i++;

}

if(a[0]==a[4]a[1]==a[3])

printf("这个数是回文数 ");

else

printf("这个数不是回文数 ");

return 0;

}

8.利用递归算法,将所输入的5个字符,以相反顺序打印出来。

#include

void digui(char a[],int n)

{

if(n==1)

printf("%c",a[0]);

else

{

printf("%c",a[n-1]);

digui(a,n-1);

}

}

int main()

{

char str[5];

printf("请输入5个字符:");

scanf("%s",str);

digui(str,5);

printf(" ");

return 0;

}

9.有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13…球出这个序列的前20项之和。

#include

int main()

{

int i,a=1,b=1;

float sum=0.0;

for(i=1;i=20;i++)

{

sum=sum+(float)(a+i)/b;

b=a+i;

a=i;

}

printf("sum=%f ",sum);

return 0;

}

10.利用递归算法求5!。

#include

int digui(int n)

{

if(n==1)

return 1;

else

return n*digui(n-1);

}

int main()

{

int n,sum;

printf("n:");

scanf("%d",n);

sum=digui(n);

printf("sum=%d ",sum);

return 0;

}


推荐阅读
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 本文介绍了一种划分和计数油田地块的方法。根据给定的条件,通过遍历和DFS算法,将符合条件的地块标记为不符合条件的地块,并进行计数。同时,还介绍了如何判断点是否在给定范围内的方法。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 本文详细介绍了GetModuleFileName函数的用法,该函数可以用于获取当前模块所在的路径,方便进行文件操作和读取配置信息。文章通过示例代码和详细的解释,帮助读者理解和使用该函数。同时,还提供了相关的API函数声明和说明。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • C# 7.0 新特性:基于Tuple的“多”返回值方法
    本文介绍了C# 7.0中基于Tuple的“多”返回值方法的使用。通过对C# 6.0及更早版本的做法进行回顾,提出了问题:如何使一个方法可返回多个返回值。然后详细介绍了C# 7.0中使用Tuple的写法,并给出了示例代码。最后,总结了该新特性的优点。 ... [详细]
author-avatar
丁郁翰761891
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有