當前位置:首頁 » 編程軟體 » 有趣的編程題

有趣的編程題

發布時間: 2023-07-29 12:19:13

c語言編程

//解:狗熊吃玉米問題
#include<stdio.h>
intEatCorn(intdays)//遞歸調用狗熊吃玉米
{
if(days==1)
return1;
elsereturn((EatCorn(days-1)+1)*2);//狗熊每天都吃掉前一天的一半多一個
}
voidmain(void)
{
printf("%d ",EatCorn(10));
}

//Diamond問題
#include<stdio.h>
voidmain(void)
{
for(inti=0;i<=6;i++)//控制行數,共7行
{

if(i<4)//控制前四行
{
for(intj=0;j<=2-i;j++)
printf("%s","");//控制左邊空隙
for(intm=0;m<=i*2;m++)
printf("*");
printf(" ");
}
else//控制後三行
{
for(intv=4;v<=i;v++)
printf("%s","");
for(intn=0;n<=12-2*i;n++)//原理就是第5行(含)後遞減2
printf("*");
printf(" ");
}

}

}
//原理特別說明:
//當i=4時,則12-2*4=4(千萬不要誤會是4個星號它是5個星號,下標是0開始的,下述同理)
//當i=5時,則12-2*5=2
//當i=6時,則12-2*6=0

1、 程序菜單是很簡單的,它主要是考察了對ASCII碼,只需把char轉換成ASCII碼並判斷它是不是1---6數字,若不是則返回或者給出適當的提示。對此,太簡單就不作寫代碼了。

1)、2)、3)沒有看明白題意。

❷ C語言編程:兔子繁殖問題 這是一個有趣的古典數學問題,著名義大利數

#include <stdio.h>

int main()

{int i,f[12]={1,1};

for(i=2;i<12;i++)

f[i]=f[i-1]+f[i-2];

printf("%d ",f[11]);

return 0;

}

❸ 【C++】請你提供一些巧妙、有趣的上機練習題(3~4題即可)

http://hi..com/korpus/blog/item/165756fdebdece1308244d2e.html

C/C++語言經典、實用、趣味程序設計編程百例精解(1)2007年06月04日 星期一 20:18C/C++語言經典、實用、趣味程序設計編程百例精解(1) 1.繪制餘弦曲線2.繪制餘弦曲線和直線3.繪制圓4.歌星大獎賽5.求最大數6.高次方數的尾數7.階乘尾數零的個數8.借書方案知多少9.楊輝三角形10.數制轉換11.打魚還是曬網12.抓交通肇事犯13.該存多少錢14.怎樣存錢利最大15.捕魚和分魚16.出售金魚17.平分七筐魚18.有限5位數19.8除不盡的自然數20.一個奇異的三位數21.4位反序數22.求車速23.由兩個平方三位數獲得三個平方二位數24.阿姆斯特朗數25.完全數26.親密數27.自守數28.迴文數29.求具有abcd=(ab+cd)2性質的四位數30.求素數31.歌德巴赫猜想32.可逆素數33.迴文素數34.要發就發35.素數幻方36.百錢百雞問題37.愛因斯坦的數學題38.換分幣39.年齡幾何40.三色球問題41.馬克思手稿中的數學題42.最大公約數和最小公倍數43.分數比較44.分數之和45.將真分數分解為埃及分數46.列出真分數序列47.計算分數的精確值48.新娘和新郞49.委派任務50.誰在說謊51.誰是竊賊52.黑與白53.迷語博士的難題(1)54.迷語博士的難題(2)55.哪個大夫哪天值班56.區分旅客國籍57.誰家孩子跑最慢58.拉丁方陣59.填表格60.1~9分成1:2:3的三個3位數61.1~9組成三個3位的平方數62.由8個整數形成奇特的立方體63.減式還原64.乘式還原65.乘式還原(2)66.除式還原(1)67.除式還原(2)68.九位累進可除數69.魔術師的猜牌術(1)70.魔術師的猜牌術(2)71.約瑟夫問題72.郵票組合73.和數能表示1~23的5個正整數74.可稱1~40磅的4塊砝碼75.10個小孩分糖果76.小明買書77.波松瓦酒的分酒趣題78.求π的近似值79.求π的近似值(2)80.奇數平方的一個有趣性質81.角谷猜想82.四方定理83.卡布列克常數84.尼科徹斯定理85.迴文數的形成86.自動發牌87.黑白子交換88.常勝將軍89.搶3090.搬山游戲91.人機猜數游戲92.人機猜數游戲(2)93.漢諾塔94.兎子產子95.將阿拉伯數字轉換為羅馬數字96.選美比賽97.滿足特異條件的數列98.八皇後問題99.超長正整數的加法100.數字移動

java編程題 有趣的數

就你出的題來說,沒看懂,就java來說表示起始2,一直到N做循環
import java.util.Scanner;

public class FunNumber {

public static void main(String[] args) {
Scanner fin = new Scanner(System.in);
int N = fin.nextInt();

long i = (long)Math.pow(10, N-1);
long j = (long)Math.pow(10, N);
long count = 0;
for(;i<j;i++){
if(isFun(i,N)) {
count++;
System.out.println(i);
}
}
System.out.println("Count % 1000000007 = " + count%1000000007);

}
public static boolean isFun(long num,int N){
boolean[] num_exist = new boolean[4];

for(;N>0;N--){
int i = (int)(num%Math.pow(10,N)/Math.pow(10,N-1));
switch(i){
case 0:
num_exist[0] = true;
//0必須都在1前
if(num_exist[1]){
return false;
}
break;
case 1:
num_exist[1] = true;
break;
case 2:
num_exist[2] = true;
//2必須都在3前
if(num_exist[3]){
return false;
}
break;
case 3:
num_exist[3] = true;
break;
default:
//不只包含0123
return false;
}

}
//0123至少出現1次
if(num_exist[0]&&num_exist[1]&&num_exist[2]&&num_exist[3]){
return true;
}
return false;

}

}

❺ c語言能寫出什麼樣有意思的小程序

  1. C語言是一門通用計算機編程語言,應用廣泛。

  2. C語言的設計目標是提供一種能以簡易的方式編譯、處理低級存儲顫銷器、產生少量的機器碼以及不需要任何運行環境支持便能運行的編程語言。

  3. C語言提供了許多低級處理的功能,但仍然保持著良好跨平台的特性,以一個標准規格寫出的C語言程序可在許多電腦平台上進行編譯,甚至包含一些嵌入式處理器(單片機或稱MCU)以及超級電腦等作業平台。

  4. 題目:有1、2、3、4個數字,能組成多少個互不相同且無重復數字的三位數?都是多茄派游少?

程序分析:可填在百位、十位、個位的數字都是1、2、3、4。組成所有的排列後再去掉不滿足條件的排列。

程序源代碼:

main()

{int i,j,k;printf( );for(i=1;i<5;i++)/*以下為三重循環*/for(j=1;j<5;j++)

for (k=1;k<5;k++),{f (i!=ki!=jj!=k) /*確保i、j、k三位互不相同*/printf(%d,%d,%d ,i,j,k); }}

題目:企業發放的獎金根據利潤提成。利潤(I)低於或等於10萬元時,獎金可提10%;利潤高 於10萬元,低於20萬元時,低於10萬元的部分按10%提成,高於10萬元的部分,可可提 成7.5%;20萬到40萬之間時,高於20萬元的部分,可提成5%;40萬到60萬之間時高於40萬元的部分,可提成3%;60萬到100萬之間時,高於60萬元的部分,可提成1.5%,高於100萬元時,羨頌超過100萬元的部分按1%提成,從鍵盤輸入當月利潤I,求應發放獎金總數?

程序分析:請利用數軸來分界,定位。注意定義時需把獎金定義成長整型。

程序源代碼:

main()

{

long int i;

int bonus1,bonus2,bonus4,bonus6,bonus10,bonus;

scanf(%ld,i);

bonus1=100000*0.1;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;

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);

}

6.題目:一個整數,它加上100後是一個完全平方數,再加上168又是一個完全平方數,請問該數是多少?

程序分析:在10萬以內判斷,先將該數加上100後再開方,再將該數加上268後再開方,如果開方後 的結果滿足如下條件,即是結果。

程序源代碼:

#include math.h

main()

{

long int i,x,y,z;

for (i=1;i<100000;i++)

{ x=sqrt(i+100); /*x為加上100後開方後的結果*/

y=sqrt(i+268); /*y為再加上168後開方後的結果*/

if(x*x==i+100y*y==i+268)/*如果一個數的平方根的平方等於該數,這說明此數是完全平方數*/

printf( %ld ,i);

}

}

7.題目:輸入某年某月某日,判斷這一天是這一年的第幾天?

程序分析:以3月5日為例,應該先把前兩個月的加起來,然後再加上5天即本年的第幾天,特殊情況,閏年且輸入月份大於3時需考慮多加一天。

程序源代碼:

main()

{

int day,month,year,sum,leap;

printf( please input year,month,day );

scanf(%d,%d,%d,year,month,day);

switch(month)/*先計算某月以前月份的總天數*/

{

case 1:sum=0;break;

case 2:sum=31;break;

case 3:sum=59;break;

case 4:sum=90;break;

case 5:sum=120;break;

case 6:sum=151;break;

case 7:sum=181;break;

case 8:sum=212;break;

case 9:sum=243;break;

case 10:sum=273;break;

case 11:sum=304;break;

case 12:sum=334;break;

defaultrintf(data error);break;

}

sum=sum+day; /*再加上某天的天數*/

if(year%400==0||(year%4==0year%100!=0))/*判斷是不是閏年*/

leap=1;

else

leap=0;

if(leap==1month>2)/*如果是閏年且月份大於2,總天數應該加一天*/

sum++;

printf(It is the %dth day.,sum); }

8.題目:輸入三個整數x,y,z,請把這三個數由小到大輸出。

程序分析:我們想辦法把最小的數放到x上,先將x與y進行比較,如果x>y則將x與y的值進行交換,然後再用x與z進行比較,如果x>z則將x與z的值進行交換,這樣能使x最小。

程序源代碼:

main()

{

int x,y,z,t;

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

if (x>y)

/*交換x,y的值*/

if(x>z)

/*交換x,z的值*/

if(y>z)

/*交換z,y的值*/

printf(small to big: %d %d %d ,x,y,z);

}

9.題目:用*號輸出字母C的圖案。

程序分析:可先用<|>*<|>號在紙上寫出字母C,再分行輸出。

程序源代碼:

#include stdio.h

main()

{

printf(Hello C-world! );

printf( **** );

printf( * );

printf( * );

printf( **** );

}

10.題目:輸出特殊圖案,請在c環境中運行,看一看,Very Beautiful!

程序分析:字元共有256個。不同字元,圖形不一樣。

程序源代碼:

#include stdio.h

main()

{

char a=176,b=219;

printf(%c%c%c%c%c ,b,a,a,a,b);

printf(%c%c%c%c%c ,a,b,a,b,a);

printf(%c%c%c%c%c ,a,a,b,a,a);

printf(%c%c%c%c%c ,a,b,a,b,a);

printf(%c%c%c%c%c ,b,a,a,a,b); }

11.題目:輸出9*9口訣。

程序分析:分行與列考慮,共9行9列,i控制行,j控制列。

程序源代碼:

#include stdio.h

main()

{

int i,j,result;

printf( );

for (i=1;i<10;i++)

{ for(j=1;j<10;j++)

{

result=i*j;

printf(%d*%d=%-3d,i,j,result);/*-3d表示左對齊,佔3位*/

}

printf( );/*每一行後換行*/

}

}

12.題目:要求輸出國際象棋棋盤。

程序分析:用i控制行,j來控制列,根據i+j的和的變化來控制輸出黑方格,還是白方格。

程序源代碼:

#include stdio.h

main()

{

int i,j;

for(i=0;i<8;i++)

{

for(j=0;j<8;j++)

if((i+j)%2==0)

printf(%c%c,219,219);

else

printf( );

printf( );

}

}

13.題目:列印樓梯,同時在樓梯上方列印兩個笑臉。

程序分析:用i控制行,j來控制列,j根據i的變化來控制輸出黑方格的個數。

程序源代碼:

#include stdio.h

main()

{

int i,j;

printf( );/*輸出兩個笑臉*/

for(i=1;i<11;i++)

{

for(j=1;j<=i;j++)

printf(%c%c,219,219);

printf( );

}

❻ 一道趣味小編程(一疊N張卡片)

有時間你自己再測一下吧!
#include<iostream>
#include<vector>
using namespace std;
int Jhpx(vector<int>*,int,int*);
int main()
{
vector<int>n;
int x=0,pd=0; //x統計下次所須的循環數,pd判斷第一個是存還是丟棄
//如果pd=0,則第一張丟棄,反之保存
cout<<"請輸入牌的張數:";
cin>>x;
for (int a=1;a<=x;a++)
{
n.push_back(a); //順序賦值:1至x;
}
while (true)
{
x=Jhpx(&n,x,&pd);
if (x==1)
{
cout<<"最後留下樑戚的那一張牌為原來的 "<<n[0]<<" 號牌"<<endl;
break;
}
}
return 0;
}
int Jhpx(vector<int> *P,int x,int *pd)
{
int temp=0,save=0,del=0; //save存的次數,del刪的次數
vector<int>tmp; //臨時交換用
if (*pd==0) //第一張丟棄
{
for (int a=1;a<=x;a++)
{
temp=a-1;
if (a%2>0) //如果為單橡汪陵數則丟棄
{
(*P)[temp]=0;
del++;
}
else //反之臨時存儲
{
tmp.push_back((*P)[temp]);
(*P)[temp]=0;
save++;
}
}
for (int b=0;b<save;b++) //臨時存儲中取出到原容器
{
(*P)[b]=tmp[b];
}
if (del>save) //這里判斷接下來一圈陵李的第一張是否丟棄
{
*pd=1;
}
else
{
*pd=0;
}
}
else //第一張保存
{
for (int a=1;a<=x;a++)
{
temp=a-1;
if (a%2==0)
{
(*P)[temp]=0;
del++;
}
else
{
tmp.push_back((*P)[temp]);
(*P)[temp]=0;
save++;
}
}
for (int b=0;b<save;b++)
{
(*P)[b]=tmp[b];
}
if (del>save)
{
*pd=1;
}
else
{
*pd=0;
}
}
return save;
}

熱點內容
如何配置2檸檬酸 發布:2025-02-06 00:57:26 瀏覽:434
積木源碼 發布:2025-02-06 00:55:26 瀏覽:545
變分的運演算法則 發布:2025-02-06 00:55:21 瀏覽:775
x2哪個配置性價比高 發布:2025-02-06 00:40:12 瀏覽:109
豬哥亮訪問張菲 發布:2025-02-06 00:37:52 瀏覽:570
期貨賬戶怎麼改密碼 發布:2025-02-06 00:32:35 瀏覽:279
qq自動上傳群文件 發布:2025-02-06 00:26:25 瀏覽:111
安卓照片放在什麼地方 發布:2025-02-06 00:26:24 瀏覽:988
linux系統鏡像iso 發布:2025-02-06 00:15:39 瀏覽:188
存儲上料模塊的意義 發布:2025-02-06 00:14:14 瀏覽:125