C日付が有効かどうかを確認するプログラム
日付を整数で日付、月、年の形式で指定します。タスクは、日付が可能かどうかを確認することです。
有効な日付は、1800年1月1日から9999年12月31日までの範囲である必要があります。これらを超える日付は無効です。
これらの日付には、年の範囲だけでなく、カレンダーの日付に関連するすべての制約も含まれます。
制約は-
です- 日付は1以上31を超えることはできません
- 月は1未満、12を超えることはできません
- 年は1800以上9999を超えることはできません
- 月が4月、6月、9月、11月の場合、日付は30を超えることはできません。
- 月が2月の場合、次のことを確認する必要があります。
- 年がうるう年の場合、日数は29日を超えることはできません
- それ以外の場合、日数は28日を超えることはできません。
すべての制約が真の場合は有効な日付ですが、そうでない場合はそうではありません。
例
Input: y = 2002 d = 29 m = 11 Output: Date is valid Input: y = 2001 d = 29 m = 2 Output: Date is not valid
アルゴリズム
START In function int isleap(int y) Step 1-> If (y % 4 == 0) && (y % 100 != 0) && (y % 400 == 0) then, Return 1 Step 2-> Else Return 0 In function int datevalid(int d, int m, int y) Step 1-> If y < min_yr || y > max_yr then, Return 0 Step 2-> If m < 1 || m > 12 then, Return 0 Step 3-> If d < 1 || d > 31 then, Return 0 Step 4-> If m == 2 then, If isleap(y) then, If d <= 29 then, Return 1 Else Return 0 End if End if Step 5-> If m == 4 || m == 6 || m == 9 || m == 11 then, If(d <= 30) Return 1 Else Return 0 Return 1 End Function In main(int argc, char const *argv[]) Step 1->Assign and initialize values as y = 2002, d = 29, m = 11 Step 2-> If datevalid(d, m, y) then, Print "Date is valid" Step 3-> Else Print "date is not valid” End main STOP
例
#include <stdio.h>
#define max_yr 9999
#define min_yr 1800
//to check the year is leap or not
//if the year is a leap year return 1
int isleap(int y) {
if((y % 4 == 0) && (y % 100 != 0) && (y % 400 == 0))
return 1;
else
return 0;
}
//Function to check the date is valid or not
int datevalid(int d, int m, int y) {
if(y < min_yr || y > max_yr)
return 0;
if(m < 1 || m > 12)
return 0;
if(d < 1 || d > 31)
return 0;
//Now we will check date according to month
if( m == 2 ) {
if(isleap(y)) {
if(d <= 29)
return 1;
else
return 0;
}
}
//April, June, September and November are with 30 days
if ( m == 4 || m == 6 || m == 9 || m == 11 )
if(d <= 30)
return 1;
else
return 0;
return 1;
}
int main(int argc, char const *argv[]) {
int y = 2002;
int d = 29;
int m = 11;
if(datevalid(d, m, y))
printf("Date is valid\n");
else
printf("date is not valid\n");
return 0;
} 出力
上記のコードを実行すると、次の出力が生成されます-
Date is valid
-
Cアレイが回文であるか、再帰を使用していないかを確認するプログラム
配列arr[n]が与えられ、nは配列のあるサイズである場合、タスクは、配列が回文であるか、再帰を使用していないことを確認することです。回文は、MADAM、NAMANなどのように、同じように前後に読み取ることができるシーケンスです。 したがって、配列が回文であるかどうかを確認するために、-のように配列を前後にトラバースできます。 再帰では、開始値と終了値を等しくなるまで変更する必要があります。または、開始値と終了値が等しくない場合は、終了して、指定された配列が回文ではないことをfalseに返します。 例 Input: arr[] = { 2, 3, 4, 3, 2} Output: Y
-
アレイが回文であるかどうかをチェックするCプログラム
任意のサイズnの配列arr[]が与えられた場合、私たちのタスクは、配列が回文であるかどうかを確認することです。回文は、MADAM、NAMANなどのように、同じように前後に読み取ることができるシーケンスです。 したがって、配列が回文であるかどうかを確認するために、-のように配列を前後にトラバースできます。 例 Input: arr[] = {1, 0, 0, 1} Output: Array is palindrome Input: arr[] = {1, 2, 3, 4, 5} Output: Array is not palindrome 以下で使用されるアプローチは次のとおりです