ホームページ バックエンド開発 PHPチュートリアル こんにちはキキ&&http://acm.hdu.edu.cn/showproble_PHP チュートリアル

こんにちはキキ&&http://acm.hdu.edu.cn/showproble_PHP チュートリアル

Jul 13, 2016 pm 05:52 PM
amp http pid

問題の説明
ある日、私はスーパーで買い物をしていました。レジ係が真剣に小銭を数えていると、小さな子供が「门前大桥下游过一群鸭、快来快来数一数、二四六七八」と歌いながら走っていた。そしてレジ係は数えたコインを不機嫌そうに戻してまた数えました...
こんにちは、キキはとても素敵な女の子で、別の方法で数を数えるのが大好きです。たとえば、X 枚のコインを数えるとき、N 回数えます。毎回、彼女はコインをいくつかの同じサイズのグループに分け、グループのサイズ Mi と残りのコインの数 Ai をメモに書き留めます。
ある日、キキの父親がキキのメモを見つけて、キキが数えているコインの枚数を知りたがりました。

入力

最初の行は T で、テスト ケースの数を示します。
各ケースには、1 行目に N、2 行目に Mi(1 入力と出力の数値はすべて整数です。
1

出力

それぞれのケースについて、サンプル出力形式で Kiki が数えていた最小の正の整数 X を出力します。解決策がない場合は、-1 を出力します。

サンプル入力

2
2
14 57
5 56
5
19 54 40 24 80
11 2 36 20 76

サンプル出力
ケース 1: 341
ケース 2: 5996
質問の意味: お金を数えるさまざまな方法を教えて、要件を満たす最低金額を見つけてください。
アイデア: 一見すると中国剰余定理に関する問題のように見えますが、この問題の法は必ずしもペアごとの逆素数ではありません。したがって、これは拡張ユークリッド アルゴリズムを理解する必要があるモジュラー線形方程式を解くことによって実行できます。そのアイデアは、2 つを継続的にマージして取得することです。まず 2 つの合同方程式を見つけ、一般解を N、N=r1(mod(m1))、N=r2(mod(m2)) とします。これは明らかに k1*m1+r1=k2*m2 に変換できます。 +r2 ;--->k1*m1+(-k2*m2)=r2-r1; a=m1,b=m2,x=k1,y=(-k2),c=r2-r1 という式が成り立つと仮定します。 ax +by=c と書きます。拡張ユークリッドで x を解き、x を元の方程式の最小の正の整数解 (x*(c/d)%(b/d)+(b/d) に変換します。 %(b/d); この場合、この x は元の方程式の最小の整数解になります。したがって、N=a*(x+n*(b/d))+r1====N=(a*b/d)*n+(a*x+r1)、ここで n だけが未知の数であるため、これは別の式 N=(a*x+r1)(mod(a*b/d)) であり、2 つの式を 1 つの式に変換し続ける限り、最終的にこの解を解くことができます。方程式系
ACコード:
[CP]
#include #include #include<文字列> #include #N 7 を定義します
名前空間 std を使用します。 int M[N],A[N]; int Gcd(int a,int b)
{return b==0?a:Gcd(b,a%b);}
void gcd(int a,int b,int &d,int &x,int &y)
{
If(!b) x=1、y=0、d=a; else gcd(b,a%b,d,y,x),y-=a/b*x; }
int main()
{
整数
Scanf("%d",&T); for(int k=1;k {
整数
scanf("%d",&n); for(int i=0;i!=n;++i) scanf("%d",&M[i]); for(int i=0;i!=n;++i) scanf("%d",&A[i]); int x,y,d
int a=M[0],c1=A[0]; bool flag=false
for(int i=1;i                                                                                int b=M[i]; int c=A[i]-c1; gcd(a,b,d,x,y); If(c%d){flag=true;break;}
int r=b/d; x=(c/d*x%r+r)%r; c1=a*x+c1; a=a*r; }
If(フラグ) printf("ケース %d: -1n",k); それ以外
                                                            int ans=1; If(c1==0)//すべての剰余が 0 の特殊なケース
                                                                for(int i=0;i!=n;++i)
ans=M[i]/Gcd(ans,M[i])*ans; printf("ケース %d: %dn",k,ans);                                                                        else printf("Case %d: %dn",k,c1); }
} 0 を返します。 }

作者: smallacmer

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/478105.html技術記事問題の説明 ある日、スーパーで買い物をしていると、レジ係が真剣に小銭を数えているとき、小さな子供が走りながら歌いました アヒルの群れが門の前の橋の下を通り過ぎました、急いでください...
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

http ステータス コード 520 は何を意味しますか? http ステータス コード 520 は何を意味しますか? Oct 13, 2023 pm 03:11 PM

HTTP ステータス コード 520 は、サーバーがリクエストの処理中に不明なエラーに遭遇し、より具体的な情報を提供できないことを意味します。サーバーがリクエストを処理しているときに不明なエラーが発生したことを示すために使用されます。サーバー構成の問題、ネットワークの問題、またはその他の不明な理由が原因である可能性があります。これは通常、サーバー構成の問題、ネットワークの問題、サーバーの過負荷、またはコーディング エラーが原因で発生します。ステータス コード 520 エラーが発生した場合は、Web サイト管理者またはテクニカル サポート チームに連絡して詳細情報と支援を得ることが最善です。

Nginx プロキシ マネージャーを使用して HTTP から HTTPS への自動ジャンプを実装する方法 Nginx プロキシ マネージャーを使用して HTTP から HTTPS への自動ジャンプを実装する方法 Sep 26, 2023 am 11:19 AM

NginxProxyManager を使用して HTTP から HTTPS への自動ジャンプを実装する方法 インターネットの発展に伴い、ますます多くの Web サイトが HTTPS プロトコルを使用してデータ送信を暗号化し、データ セキュリティとユーザーのプライバシー保護を向上させ始めています。 HTTPS プロトコルは SSL 証明書のサポートを必要とするため、HTTPS プロトコルを展開する際には特定の技術サポートが必要です。 Nginx は強力で一般的に使用される HTTP サーバーおよびリバース プロキシ サーバーであり、NginxProxy

httpステータスコード403とは何ですか? httpステータスコード403とは何ですか? Oct 07, 2023 pm 02:04 PM

HTTP ステータス コード 403 は、サーバーがクライアントの要求を拒否したことを意味します。 http ステータス コード 403 の解決策は次のとおりです: 1. 認証資格情報を確認します。サーバーが認証を必要とする場合は、正しい資格情報が提供されていることを確認します。2. IP アドレス制限を確認します。サーバーが IP アドレスを制限している場合は、クライアントの IP アドレスは制限されています。ホワイトリストに登録されているか、ブラックリストに登録されていません。3. ファイルのアクセス許可設定を確認します。403 ステータス コードがファイルまたはディレクトリのアクセス許可設定に関連している場合は、クライアントがこれらのファイルまたはディレクトリにアクセスするための十分なアクセス許可を持っていることを確認してください。等

Web ページのリダイレクトの一般的なアプリケーション シナリオを理解し、HTTP 301 ステータス コードを理解する Web ページのリダイレクトの一般的なアプリケーション シナリオを理解し、HTTP 301 ステータス コードを理解する Feb 18, 2024 pm 08:41 PM

HTTP 301 ステータス コードの意味を理解する: Web ページ リダイレクトの一般的なアプリケーション シナリオ インターネットの急速な発展に伴い、Web ページの操作に対する人々の要求はますます高くなっています。 Web デザインの分野では、Web ページのリダイレクトは一般的かつ重要なテクノロジであり、HTTP 301 ステータス コードによって実装されます。この記事では、HTTP 301 ステータス コードの意味と、Web ページ リダイレクトにおける一般的なアプリケーション シナリオについて説明します。 HTTP301 ステータス コードは、永続的なリダイレクト (PermanentRedirect) を指します。サーバーがクライアントのメッセージを受信すると、

クイックアプリケーション: PHP 複数ファイルの非同期 HTTP ダウンロードの実践的な開発事例分析 クイックアプリケーション: PHP 複数ファイルの非同期 HTTP ダウンロードの実践的な開発事例分析 Sep 12, 2023 pm 01:15 PM

クイック アプリケーション: PHP の実践的な開発ケース分析 複数ファイルの非同期 HTTP ダウンロード インターネットの発展に伴い、ファイル ダウンロード機能は多くの Web サイトやアプリケーションの基本的なニーズの 1 つになりました。複数のファイルを同時にダウンロードする必要があるシナリオでは、従来の同期ダウンロード方法は非効率的で時間がかかることがよくあります。このため、PHP を使用して HTTP 経由で複数のファイルを非同期にダウンロードするソリューションがますます一般的になってきています。この記事では、実際の開発事例を通して、PHP 非同期 HTTP の使用方法を詳しく分析します。

http.PostForm 関数を使用してフォーム データを含む POST リクエストを送信する http.PostForm 関数を使用してフォーム データを含む POST リクエストを送信する Jul 25, 2023 pm 10:51 PM

http.PostForm 関数を使用して、フォーム データを含む POST リクエストを送信します。Go 言語の http パッケージでは、http.PostForm 関数を使用して、フォーム データを含む POST リクエストを送信できます。 http.PostForm 関数のプロトタイプは次のとおりです。 funcPostForm(urlstring,dataurl.Values)(resp*http.Response,errerror)where, u

httpリクエスト415エラーの解決策 httpリクエスト415エラーの解決策 Nov 14, 2023 am 10:49 AM

解決策: 1. リクエスト ヘッダーの Content-Type を確認する; 2. リクエスト本文のデータ形式を確認する; 3. 適切なエンコード形式を使用する; 4. 適切なリクエスト メソッドを使用する; 5. サーバー側のサポートを確認する。

C# における一般的なネットワーク通信とセキュリティの問題と解決策 C# における一般的なネットワーク通信とセキュリティの問題と解決策 Oct 09, 2023 pm 09:21 PM

C# におけるネットワーク通信とセキュリティの一般的な問題と解決策 今日のインターネット時代では、ネットワーク通信はソフトウェア開発に不可欠な部分となっています。 C# では通常、データ送信のセキュリティ、ネットワーク接続の安定性など、ネットワーク通信の問題が発生します。この記事では、C# における一般的なネットワーク通信とセキュリティの問題について詳しく説明し、対応する解決策とコード例を提供します。 1. ネットワーク通信の問題 ネットワーク接続の中断: ネットワーク通信プロセス中に、ネットワーク接続が中断される場合があります。

See all articles